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

前言

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

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

官网

通过官网来查看如何使用python读取Excel,python excel官网: Python Resources for working with Excel - Working with Excel Files in Python

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

2、点击“文档”

3、点击“安装说明”

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

 

环境准备

1、以下是小编环境是:

操作系统:win10

python环境:python3.7

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

 

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

 python对Excel的基本操作

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

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

3、实例1

(1)Excel内容

 

(2)代码实现

(3)运行结果

(4)参考代码1

1 # coding=utf-8
 2 # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
 3 
 4 # 2.注释:包括记录创建时间,创建人,项目名称。
 5 '''
 6 Created on 2019-5-20
 7 @author: 锦都不二
 8 Project:学习和使用python读取Excel
 9 '''
10 # 3.导入模块
11 import xlrd
12 
13 if __name__ == '__main__':
14 
15     # excel文件全路径
16     xlPath = "C:\\Users\\DELL\\Desktop\\test.xlsx"
17     # 用于读取excel
18     xlBook = xlrd.open_workbook(xlPath)
19     # 获取excel工作簿数
20     count = len(xlBook.sheets())
21     print(u"工作簿数为:  ", count)
22     # 获取 表 数据的行列数
23     table = xlBook.sheets()[0]
24     nrows = table.nrows
25     ncols = table.ncols
26     print(u"表数据行列为(%d, %d)" % (nrows, ncols))
27     # 循环读取数据
28     for i in range(0, nrows):
29         rowValues = table.row_values(i)  # 按行读取数据
30         # 输出读取的数据
31         for data in rowValues:
32             print(data, " ",)
33         print("")

 4、参考代码2

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

5、以上代码运行结果

Excel存放数据(参数)

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

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

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

2、封装好的代码如下:

 

3、运行结果

小结

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

 

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

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

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

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

 

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

 感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

 

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取 

 

  • 22
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python接口自动化中,POST请求是常见的一种请求方式。POST请求通常用于向服务器提交数据,比如表单数据、JSON数据等。在Python中,我们可以使用requests库来发送POST请求。具体步骤如下: 1. 导入requests库 ``` import requests ``` 2. 构造请求参数 POST请求通常需要传递一些参数,比如表单数据、JSON数据等。我们可以使用字典来构造请求参数。 ``` data = { 'username': 'admin', 'password': '123456' } ``` 3. 发送POST请求 使用requests库的post方法来发送POST请求,传递请求的URL和请求参数即可。 ``` url = 'http://www.example.com/login' response = requests.post(url, data=data) ``` 4. 处理响应结果 发送POST请求后,服务器会返回响应结果。我们可以通过response对象来获取响应结果。 ``` print(response.status_code) # 获取响应状态码 print(response.text) # 获取响应内容 ``` 以上就是Python接口自动化中发送POST请求的基本步骤。 ### 回答2: Python接口自动化中,Post请求是常用的一种请求方式,通常用于向服务器提交数据。Post请求与Get请求不同,它将请求参数放在请求体中,而不是放在URL的参数中。 在Python中,可以使用requests库来发送Post请求,其基本用法示例如下: ``` import requests # 构造请求参数 url = "http://www.example.com/api" data = { "username": "xxx", "password": "xxx" } # 发送Post请求 response = requests.post(url, data=data) # 解析响应数据 result = response.json() ``` 以上示例中,首先构造了请求参数,包括请求URL和请求数据。然后使用requests库发送Post请求,其中url参数传入请求URL,data参数传入请求数据。发送请求后,可以通过response.json()方法将响应数据解析为JSON格式的数据,方便后续操作。 在实际使用中,请求参数的构造可能更加复杂,包括请求头、cookies等,可以通过requests库提供的各种方法进行设置。另外,在接口自动化中,需要进行接口测试的时候,通常需要用到断言,可以使用Python自带的assert语句或其他第三方断言库来进行断言操作。 总之,在Python接口自动化中,Post请求是常见的请求方式,使用requests库可以轻松实现Post请求的发送和响应解析,同时也可以进行断言操作,方便进行接口测试。 ### 回答3: Python接口自动化中,使用POST请求是非常常见的操作。POST请求是HTTP协议中的一种请求方式,主要用于向服务器提交数据。相较于GET请求,POST请求通常用于提交表单数据、上传文件和请求创建新资源等场景。 下面我们来介绍Python中如何实现POST请求的操作。 首先需要导入requests库: ```python import requests ``` 接下来,我们可以定义一个POST请求的函数,传入URL、参数和请求头部(可选): ```python def post_request(url, data, headers=None): """ POST请求 """ response = requests.post(url=url, data=data, headers=headers) # 返回响应结果 return response ``` 以上代码中,我们使用requests.post()方法发送POST请求,传入URL、参数和请求头部。其中,URL表示请求的URL地址,data表示请求的数据,headers表示请求头部,可选。 接着,我们可以通过调用上面定义的函数,发送POST请求并获取响应结果: ```python url = "http://example.com/api/login" data = { "username": "testuser", "password": "testpass" } headers = { "User-Agent": "Mozilla/5.0" } # 发送POST请求 response = post_request(url=url, data=data, headers=headers) # 输出响应结果 print(response.text) ``` 以上代码中,我们定义了一个POST请求的URL地址和请求数据,以及一个请求头部(User-Agent)。然后,我们调用post_request()函数,传入URL、数据和请求头,发送POST请求并获取响应结果。最后,我们输出响应结果的文本内容。 除了以上的方式,我们还可以通过requests库的其他方法实现POST请求,如下所示: ```python # 使用JSON格式数据发送POST请求 response = requests.post(url=url, json=data, headers=headers) # 使用文件上传方式发送POST请求 files = {'file': open('file.png', 'rb')} response = requests.post(url=url, files=files, headers=headers) ``` 以上代码分别演示了通过JSON格式数据和文件上传方式发送POST请求的方法。 总的来说,Python实现接口自动化中的POST请求操作,其实就是通过requests库提供的post()方法或其他方法,传入请求的URL、数据和请求头部,即可实现。同时,需要注意请求参数的格式和请求头部的设置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值