Python+Requests+Excel接口测试实战

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

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

 1 import xlrd
 2 
 3 
 4 class readExcel(object):
 5     def __init__(self, path):
 6         self.path = path
 7 
 8     @property
 9     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 requests
 2 import json
 3 from xl.read_xl import readExcel
 4 from pubulic_way.get_token import get_token
 5 
 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 baseTest
 2 from xl.read_xl import readExcel
 3 from pubulic_way.test_api_way import testApi
 4 import unittest
 5 
 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来展示。展示一张报告的切图。

正在学习测试的小伙伴可以通过点击下面的小卡片一起交流吧

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/37084.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

flutter开发实战-Running Gradle task ‘assembleDebug‘ 的解决方法

flutter开发实战-Running Gradle task ‘assembleDebug‘ 的解决方法 使用Android studio经常出现Running Gradle task ‘assembleDebug‘问题,记录一下解决方法。 一、在Android目录下更改build.gradle 将repositories中的google(), mavenCentral() repositori…

从钢铁行业数字化管控平台的智能进化,看超自动化能力边界

文/王吉伟 钢铁行业的数字化转型,历来都是值得探讨的热点话题。 2022年,我国粗钢产量10.13亿吨,占据了全球钢铁供给市场的半壁江山。 这组数据可谓非常抢眼,但仍旧难掩诸多企业的各种经营问题。 钢铁生产过程工序众多&#xf…

计算机网络-网络层上篇

目录 一、网络层概述 二、网络层提供的两种服务 (一)面向连接的虚电路服务 (二)无连接的数据报服务 (三)虚电路服务与数据报服务的比较 三、IPv4地址及其应用 (一)IPv4地址概…

python中的生成器(generator)

一、生成器 生成器是 Python 中非常有用的一种数据类型,它可以让你在 Python 中更加高效地处理大量数据。生成器可以让你一次生成一个值,而不是一次生成一个序列,这样可以节省内存并提高性能 二、实现generator的两种方式 python中的gener…

SuperMap iClient3D for Cesium最短路径分析

作者:Mei 目录 前言实现思路实现步骤1、构建二维网络数据集1.1拓扑检查1.2线拓扑数据集处理1.3构建二维网络数据集 2、发布网络分析服务3、实现代码 前言 在交通、消防业务场景中,如果某地发生火灾或者交通事故,需要快速规划出最短抢救路线&a…

flask计算pin码

目录 Flask计算pin码 <1> 概念 什么是pin码&#xff1f; pin码生成条件&#xff1f; 读取相关文件绕过过滤 <2> 源码分析 werkzeug 1.0.x版本 计算PIN的源码 werkzeug 2.0.x版本 计算PIN的源码 <3> 计算生成pin的脚本 CTF中 flask-pin的应用 <1…

volatile原理剖析和实例讲解

一、是什么 volatile是Java的一个关键字&#xff0c;是Java提供的一种轻量级的同步机制&#xff0c; 二、能做什么 保证了不同线程对这个变量进行操作时的可见性&#xff0c;有序性。 三、可见性 可见性主要是指一个线程修改了共享变量的值&#xff0c;另一个线程可以看见…

RPC 框架架构设计

RPC 框架架构设计 RPC 又称远程过程调用&#xff08;Remote Procedure Call&#xff09;&#xff0c;用于解决分布式系统中服务之间的调用问题。通俗地讲&#xff0c;就是开发者能够像调用本地方法一样调用远程的服务。下面我们通过一幅图来说说 RPC 框架的基本架构。 RPC 框架…

Python_与redis数据库交互

目录 redis模块的使用 连接方式 连接池 操作 设置值 获取值 管道 事务 源码等资料获取方法 python可以使用redis模块来跟redis交互 redis模块的使用 安装模块: pip3 install redis 导入模块&#xff1a;import redis 连接方式 严格连接模式&#xff1a;rredis.St…

40.RocketMQ之高频面试题大全

消息中间件如何选型 RabbitMQ erlang开发&#xff0c;对消息堆积的支持并不好&#xff0c;当大量消息积压的时候&#xff0c;会导致 RabbitMQ 的性能急剧下降。每秒钟可以处理几万到十几万条消息。 RocketMQ java开发&#xff0c;面向互联网集群化功能丰富&#xff0c;对在线业…

Win10安全中心怎么关闭?Win10安全中心关闭方法

Win10安全中心怎么关闭&#xff1f;关闭Win10的安全中心可以帮助用户自定义系统的安全和防护设置&#xff0c;但有些用户不知道怎么操作才能关闭安全中心&#xff0c;首先用户需要打开Win10电脑的设置选项&#xff0c;接着打开安全中心&#xff0c;然后关掉安全中心的实时保护、…

SQL力扣练习(六)

目录 1. 部门工资前三高的所有员工(185) 题解一(dense_rank()窗口函数&#xff09; 题解二&#xff08;自定义函数&#xff09; 2.删除重复的电子邮箱(196) 题解一 题解二&#xff08;官方解析&#xff09; 3.上升的温度(197) 解法一&#xff08;DATEDIFF()&#xff09;…

非主流币波段策略

数量技术宅团队在CSDN学院推出了量化投资系列课程 欢迎有兴趣系统学习量化投资的同学&#xff0c;点击下方链接报名&#xff1a; 量化投资速成营&#xff08;入门课程&#xff09; Python股票量化投资 Python期货量化投资 Python数字货币量化投资 C语言CTP期货交易系统开…

探究Vue源码:mustache模板引擎(5) 对比rollup与webpack,在本地搭建webpack环境

好 从本文开始 我们就来手写一下mustache这个库 他是模板引擎的一个祖先 将模板字符串编译成一个dom字符串 就是它的思想&#xff0c;这也是一个具有跨时代意义的思想 这里的话 我们还是搭一个 webpack 的项目环境 这里值得一提的是 mustache 他官方是通过rollup来进行打包的 …

【Docker】Docker的部署含服务和应用、多租环境、Linux内核的详细介绍

前言 Docker 是一个开源的应用容器引擎&#xff0c;让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux或Windows操作系统的机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。 &#x1f4d5;作者简介&#xff1a;热…

速通matplotlib库

速通matplotlib库 前言 ​ 最近在复习之前学习过的知识点&#xff0c;因此想到把学过的总结一下&#xff0c;方便后面再次复习&#xff0c;所以有了这个系列。 说明 ​ 由于标题写的是“速通”&#xff0c;因此我的想法是可以让大家看完这篇文章&#xff0c;可以上手matplotlib…

爬虫正常用哪种代理比较好?

目录 爬虫使用哪种代理IP 爬虫使用代理IP时需要考虑什么 爬虫怎么使用代理IP 爬虫使用代理IP示例代码 爬虫使用哪种代理IP 在使用代理IP进行爬虫时&#xff0c;以下几种类型的代理被认为是比较好的选择&#xff1a; 1. 高匿名代理&#xff1a;高匿名代理隐藏了真实的IP地址…

简要介绍 | 边缘计算:原理,研究现状与未来展望

注1&#xff1a;本文系“简要介绍”系列之一&#xff0c;仅从概念上对边缘计算进行非常简要的介绍&#xff0c;不适合用于深入和详细的了解。 边缘计算&#xff1a;原理&#xff0c;研究现状与未来展望 What is Edge Computing? | Moving Intelligence to the Edge 一、背景介…

漏刻有时数据可视化Echarts组件开发(27):端午地图粽情之你的家乡吃甜还是吃咸?

端午地图粽情之你的家乡吃甜还是吃咸&#xff1f; 前言Echarts创意来源Echarts核心代码1.引入外部文件2.构建HTML容器3.Echarts组件开发预置各省数据初始化DOM配置选项geo组件series组件自适应浏览器完整option选项配置代码 前言 中国各地对粽子的口味偏好存在一定的差异&…

【openGauss数据库】---设置开机自启动openGauss数据库服务

【openGauss数据库】---设置开机自启动openGauss数据库服务 &#x1f53b; 一、openGauss 自定义服务的配置文件了解&#x1f53b; 二、设置openGauss 开机自启动&#x1f53b; 三、总结—温故知新 &#x1f448;【上一篇】 &#x1f496;The Begin&#x1f496; 点点关注&am…