当前位置: 首页 > news >正文

Python+Requests+Excel接口测试实战

1、EXCEL文件接口保存方式,如图。

2、然后就是读取EXCEL文件中的数据方法,如下:

 1 import xlrd2 3 4 class readExcel(object):5     def __init__(self, path):6         self.path = path7 8     @property9     def getSheet(self):
10         # 获取索引
11         xl = xlrd.open_workbook(self.path)
12         sheet = xl.sheet_by_index(0)
13         return sheet
14 
15     @property
16     def getRows(self):
17         # 获取行数
18         row = self.getSheet.nrows
19         return row
20 
21     @property
22     def getCol(self):
23         # 获取列数
24         col = self.getSheet.ncols
25         return col
26 
27     # 以下是分别获取每一列的数值
28     @property
29     def getName(self):
30         TestName = []
31         for i in range(1, self.getRows):
32             TestName.append(self.getSheet.cell_value(i, 0))
33         return TestName
34 
35     @property
36     def getData(self):
37         TestData = []
38         for i in range(1, self.getRows):
39             TestData.append(self.getSheet.cell_value(i, 1))
40         return TestData
41 
42     @property
43     def getUrl(self):
44         TestUrl = []
45         for i in range(1, self.getRows):
46             TestUrl.append(self.getSheet.cell_value(i, 2))
47         return TestUrl
48 
49     @property
50     def getMethod(self):
51         TestMethod = []
52         for i in range(1, self.getRows):
53             TestMethod.append(self.getSheet.cell_value(i, 3))
54         return TestMethod
55 
56     @property
57     def getUid(self):
58         TestUid = []
59         for i in range(1, self.getRows):
60             TestUid.append(self.getSheet.cell_value(i, 4))
61         return TestUid
62 
63     @property
64     def getCode(self):
65         TestCode = []
66         for i in range(1, self.getRows):
67             TestCode.append(self.getSheet.cell_value(i, 5))
68         return TestCode

 3、EXCEL中的数据读取成功后,然后我们需要对于读出来的数据进行相应的处理。如下。当然示例中只是简单列了一下关于POST,GET等二种方式,实际还有很多其它方式,如put,delete等,请求中也还会包括headers,这些都可以自已添加上去。

 1 import requests2 import json3 from xl.read_xl import readExcel4 from pubulic_way.get_token import get_token5 6 7 class testApi(object):8     def __init__(self, method, url, data):9         self.method = method
10         self.url = url
11         self.data = data
12 
13 
14     @property
15     def testApi(self):
16         # 根据不同的访问方式来访问接口
17         try:
18             if self.method == 'post':
19                 r = requests.post(self.url, data=json.dumps(eval(self.data)))
20             elif self.method == 'get':
21                 r = requests.get(self.url, params=eval(self.data))
22             return r
23         except:
24             print('失败')
25 
26     def getCode(self):
27         # 获取访问接口的状态码
28         code = self.testApi.json()['error']
29         return code
30 
31     def getJson(self):
32         # 获取返回信息的json数据
33         json_data = self.testApi.json()
34         return json_data

4、最后我们就可以调用之前准备好的方法进去测试了。

1 from base.base_test import baseTest2 from xl.read_xl import readExcel3 from pubulic_way.test_api_way import testApi4 import unittest5 6 7 class testLoginApi(unittest.TestCase):8     def testLoginApi(self):9         '''测试发布评伦接口。'''
10         excel = readExcel(r'F:\path\add_thread_data.xlsx')
11         name = excel.getName
12         data = excel.getData
13         url = excel.getUrl
14         method = excel.getMethod
15         uid = excel.getUid
16         code = excel.getCode
17         row = excel.getRows
18         for i in range(0, row - 1):
19             api = testApi(method[i], url[i], data[i])
20             apicode = api.getCode()
21             apijson = api.getJson()
22             if apicode == code[i]:
23                 print('{}、{}:测试成功。json数据为:{}'.format(i + 1, name[i], apijson))
24             else:
25                 print('{}、{}:测试失败'.format(i + 1, name[i]))
26 
27 
28 if __name__ == '__main__':
29     unittest.main(verbosity=2)

5、最后还需要把我们的结果展示出来,这个就很简单了,利用htmltestrunner来展示。展示一张报告的切图。


下面是配套学习资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

http://www.lryc.cn/news/165467.html

相关文章:

  • 10:STM32------I2C通信
  • Git多人开发解决冲突案例
  • 医疗机构如何维护电力系统?来看看这个小技巧
  • 时序预测 | MATLAB实现ELM极限学习机时间序列预测未来
  • 【数据分享】1901-2022年我国省市县镇四级的逐年平均气温数据(免费获取/Shp/Excel格式)
  • 【Axure高保真原型】日历日期原型模板
  • 深入了解接口测试:Postman 接口测试指南
  • 【ROS】Ubuntu20.04+ROS Noetic 配置PX4-v1.12.2和Gazebo11联合仿真环境【教程】
  • Java 代理模式之静态代理与动态代理
  • 打造基于终端命令行的IDE,Termux配置Vim C++开发环境
  • 【初阶C语言】操作符2---表达式求值
  • 代码随想录day50|123. 买卖股票的最佳时机 III188. 买卖股票的最佳时机 IV
  • Word 表格单元格无法垂直居中
  • python实现Flask POST Demo
  • 3-Pytorch张量的运算、形状改变、自动微分
  • 用户权限数据转换为用户组列表(3/3) - Excel PY公式
  • VS2022+CMAKE+OPENCV+QT+PCL安装及环境搭建
  • JavaScript的内置类
  • 6.英语的十六种时态(三面旗):主动、被动、肯定、否定、一般疑问句、特殊疑问句。
  • SpringBoot连接Redis与Redisson【代码】
  • ardupilot开发 --- MAVSDK 篇
  • 腾讯云AI超级底座新升级:训练效率提升幅度达到3倍
  • AB测试结果分析
  • Python模块和包:sys模块、os模块和变量函数的使用
  • 计算机软件工程毕业设计题目推荐
  • 嵌入式学习笔记(25)串口通信的基本原理
  • c++学习第十三
  • java复习-线程的同步和死锁
  • Qt指示器设置
  • 计算机网络第四节 数据链路层