python接口自动化(三十七)-封装与调用--读取excel 数据(详解)

简介: 在进行软件接口测试或设计自动化测试框架时,一个不比可避免的过程就是: 参数化,在利用python进行自动化测试开发时,通常会使用excel来做数据管理,利用xlrd、xlwt开源包来读写excel。例如:当我们登录的账号有多个的时候,我们一般用excel 存放测试数据,本篇文章介绍,python 读取excel 方法,并保存为字典格式。

简介



在进行软件接口测试或设计自动化测试框架时,一个不比可避免的过程就是: 参数化,在利用python进行自动化测试开发时,通常会使用excel来做数据管理,利用xlrd、xlwt开源包来读写excel。例如:当我们登录的账号有多个的时候,我们一般用

excel 存放测试数据,本篇文章介绍,python 读取excel 方法,并保存为字典格式。


官网



通过官网来查看如何使用python读取Excel,python excel官网: http://www.python-excel.org/


1、以下是翻译后的官网文档:


1232840-20190520100216229-654332433.png


2、点击“文档”


1232840-20190520101235338-1741101075.png

 

3、点击“安装说明”


1232840-20190520101341406-591577215.png


4、根据以上安装说明,进行准备


1232840-20190520101128682-1547343429.png


环境准备



1、以下是小编环境是:


操作系统:win10


1232840-20190520100750779-682148014.png

 

python环境:python3.7

1232840-20190520100827606-641939549.png


2、根据官方文档先安装 xlrd 模块,打开 cmd,输入 pip install xlrd 在线安装


1232840-20190520101716394-1200765055.png


3、出现红色圈的内容表示xlrd安装成功

1232840-20190520101526671-146997712.png


python对Excel的基本操作



1、打开电子表格文件以进行数据提取,官方文档API


1232840-20190520104040097-1372698205.png


2、通过工作表索引、名称获取内容


1232840-20190520115206531-1538743374.png


3、实例1


(1)Excel内容


1232840-20190520114847460-1403913047.png


(2)代码实现


1232840-20190520115325724-1081420078.png


(3)运行结果


1232840-20190520115410974-1958472211.png


(4)参考代码1


# coding=utf-8
 # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
 # 2.注释:包括记录创建时间,创建人,项目名称。
 '''
 Created on 2019-5-20
  @author: 北京-宏哥
  Project:学习和使用python读取Excel
  '''
 # 3.导入模块
 import xlrd
 if __name__ == '__main__':
     # excel文件全路径
     xlPath = "C:\\Users\\DELL\\Desktop\\test.xlsx"
     # 用于读取excel
    xlBook = xlrd.open_workbook(xlPath)
     # 获取excel工作簿数
     count = len(xlBook.sheets())
     print(u"工作簿数为:  ", count)
     # 获取 表 数据的行列数
     table = xlBook.sheets()[0]
    nrows = table.nrows
    ncols = table.ncols
     print(u"表数据行列为(%d, %d)" % (nrows, ncols))
     # 循环读取数据
     for i in range(0, nrows):
         rowValues = table.row_values(i)  # 按行读取数据
         # 输出读取的数据
         for data in rowValues:
             print(data, " ",)
       print("")

4、参考代码2


# coding=utf-8
 # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
  # 2.注释:包括记录创建时间,创建人,项目名称。
'''
 Created on 2019-5-20
  @author: 北京-宏哥
  Project:学习和使用python读取Excel
  '''
 # 3.导入模块
 import xlrd
 if __name__ == '__main__':
     # 打开 exlce 表格,参数是文件路径
     data = xlrd.open_workbook('C:\\Users\\DELL\\Desktop\\test.xlsx')
     # table = data.sheets()[0] # 通过索引顺序获取
     # table = data.sheet_by_index(0) # 通过索引顺序获取
     table = data.sheet_by_name(u'Sheet1')  # 通过名称获取
     nrows = table.nrows  # 获取总行数
     ncols = table.ncols  # 获取总列数
     # 获取一行或一列的值,参数是第几行
     print(table.row_values(0)) # 获取第一行值
     print(table.col_values(0)) # 获取第一列值


5、以上代码运行结果


1232840-20190520131225877-1308365306.png


Excel存放数据(参数)


1、在 excel 中存放数据,第一行为标题,也就是对应字典里面的 key 值,如登录的参数:username,password


1232840-20190520131844228-1459931335.png


封装读取参数或者数据方法



1、最终读取的数据是多个字典的 list 类型数据,第一行数据就是字典里的 key 值,从第二行开始一一对应 value 值


2、封装好的代码如下:


1232840-20190520145620750-1184782622.png


3、运行结果


1232840-20190520145648605-1397316611.png


小结



1、在安装xlrd模块的时候后边,还有一些黄色的警告,小伙伴们不需要的担心,翻译看一下,是需要更新pip


1232840-20190520110017114-824605163.png


2、将提示的命令选中后,回车,另起一行粘贴,运行即可将pip更新到最新版本


1232840-20190520110228385-1871871858.png


3、小伙伴们可能发现在运行结果的显示:只有出现数字就会有个.0,解决办法:

  

如果 excel 数据中有纯数字的一定要右键》设置单元格格式》文本格式,要不然读取的数据是浮点数(先设置单元格格式后编辑,编辑成功左上角有个小三角图标)



1232840-20190520150229108-1392186232.png

  

修改单元格式,运行代码结果:可以清楚看到.0没有了


1232840-20190520150333063-1584747590.png


4、好了关于python读取Excel的内容,就先讲解到这个,有兴趣可以看其官方文档对表格进行合并、样式设置等等系列动作!!!


相关文章
|
16天前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
58 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
15天前
|
图形学 Python
SciPy 空间数据2
凸包(Convex Hull)是计算几何中的概念,指包含给定点集的所有凸集的交集。可以通过 `ConvexHull()` 方法创建凸包。示例代码展示了如何使用 `scipy` 库和 `matplotlib` 绘制给定点集的凸包。
24 1
|
16天前
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
|
17天前
|
数据采集 Web App开发 iOS开发
如何使用 Python 语言的正则表达式进行网页数据的爬取?
使用 Python 进行网页数据爬取的步骤包括:1. 安装必要库(requests、re、bs4);2. 发送 HTTP 请求获取网页内容;3. 使用正则表达式提取数据;4. 数据清洗和处理;5. 循环遍历多个页面。通过这些步骤,可以高效地从网页中提取所需信息。
|
29天前
|
数据可视化 算法 JavaScript
基于图论的时间序列数据平稳性与连通性分析:利用图形、数学和 Python 揭示时间序列数据中的隐藏模式
本文探讨了如何利用图论分析时间序列数据的平稳性和连通性。通过将时间序列数据转换为图结构,计算片段间的相似性,并构建连通图,可以揭示数据中的隐藏模式。文章介绍了平稳性的概念,提出了基于图的平稳性度量,并展示了图分区在可视化平稳性中的应用。此外,还模拟了不同平稳性和非平稳性程度的信号,分析了图度量的变化,为时间序列数据分析提供了新视角。
57 0
基于图论的时间序列数据平稳性与连通性分析:利用图形、数学和 Python 揭示时间序列数据中的隐藏模式
|
15天前
|
索引 Python
SciPy 空间数据1
SciPy 通过 `scipy.spatial` 模块处理空间数据,如判断点是否在边界内、计算最近点等。三角测量是通过测量角度来确定目标距离的方法。多边形的三角测量可将其分解为多个三角形,用于计算面积。Delaunay 三角剖分是一种常用方法,可以对一系列点进行三角剖分。示例代码展示了如何使用 `Delaunay()` 函数创建三角形并绘制。
24 0
|
1月前
|
数据采集 存储 JavaScript
自动化数据处理:使用Selenium与Excel打造的数据爬取管道
本文介绍了一种使用Selenium和Excel结合代理IP技术从WIPO品牌数据库(branddb.wipo.int)自动化爬取专利信息的方法。通过Selenium模拟用户操作,处理JavaScript动态加载页面,利用代理IP避免IP封禁,确保数据爬取稳定性和隐私性。爬取的数据将存储在Excel中,便于后续分析。此外,文章还详细介绍了Selenium的基本设置、代理IP配置及使用技巧,并探讨了未来可能采用的更多防反爬策略,以提升爬虫效率和稳定性。
|
3月前
|
关系型数据库 MySQL Shell
不通过navicat工具怎么把查询数据导出到excel表中
不通过navicat工具怎么把查询数据导出到excel表中
46 0
|
1月前
|
数据处理 Python
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
这篇文章介绍了如何使用Python读取Excel文件中的数据,处理后将其保存为txt、xlsx和csv格式的文件。
51 3
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
|
1月前
|
easyexcel Java UED
SpringBoot中大量数据导出方案:使用EasyExcel并行导出多个excel文件并压缩zip后下载
在SpringBoot环境中,为了优化大量数据的Excel导出体验,可采用异步方式处理。具体做法是将数据拆分后利用`CompletableFuture`与`ThreadPoolTaskExecutor`并行导出,并使用EasyExcel生成多个Excel文件,最终将其压缩成ZIP文件供下载。此方案提升了导出效率,改善了用户体验。代码示例展示了如何实现这一过程,包括多线程处理、模板导出及资源清理等关键步骤。
下一篇
无影云桌面