Python 3 读取和存储Excel数据(应用到接口测试)

Python 3 读取和存储Excel数据(应用到接口测试)1、利用cmd命令安装第三方库openpyxl同时支持读写操作,支持的Excel是以.xlsx结尾的文件。命令:pipinstallopenpyxl【命令:pipinstallreq

大家好,又见面了,我是你们的朋友全栈君。

1、利用cmd命令安装第三方库

  openpyxl  同时支持读写操作,支持的Excel是以.xlsx结尾的文件。

   命令: pip install openpyxl

   【命令:pip install requests (安装http请求requests也是一样的)】

<span role="heading" aria-level="2">Python 3 读取和存储Excel数据(应用到接口测试)

2、新建Excel文件

  新建Excel的时候,需要在电脑上新建一个后缀为xlsx的文件,再通过复制粘贴的方式放到PyCharm工具里边。

                          <span role="heading" aria-level="2">Python 3 读取和存储Excel数据(应用到接口测试)   ——复制粘贴———-><span role="heading" aria-level="2">Python 3 读取和存储Excel数据(应用到接口测试)

3、操作工作簿

  引入工具包:from openpyxl import load_workbook

  打开工作簿:open_wb=load_workbook(‘demo_excel.xlsx’)        #传一个工作簿名称参数

  定位表单:sheet=open_wb[‘Sheet1’]                #传一个表单名,也可使用get方式获取表单

  定位坐标:value=sheet.cell(1,3).value             #获取到第一行第三列的值

  更新数据:sheet.cell(5,3).value=’abc’               #将第五行第三列的值改为abc

  保存工作簿(一般放最后):

  open_wb.save(‘demo_excel.xlsx’) 

  #调用save方法保存,但值得注意的是, 当数据更新时,需要关闭Excel表方可保存成功。

 

 4、接口测试

学习以上知识之后,我们怎么通过Python操作Excel做接口测试?get / post

(可以结合jmeter做接口测试对应记忆)

  import requests

  url=’http://………com’                     #URL地址

  req=requests.get(url)               #发起get请求

  req=requests.post(url)              #发起post请求

  login_data={“mobilephone”:“183.。。。”,”pwd”:“123”}          #传参:http请求是以字典形式传入的

 

下一个请求若需要鉴权,则需要从上一个请求中获取及在下一个请求去发送cookie、session、token,则需要接下来这些操作:  

  从返回的结果中获取cookie:(注:Python只识别:cookies,而不是cookie)

  假如此处是个简单的下单(我们用pay表示)操作:

  pay_url=”http://………” 

  pay_data={通过字典传参}

  pay_req=requests.get(参数1,参数2,cookies=req.cookies)   

        #这种方法只识别前2个值,所以传入cookie只能以上边的方法传入。

 

查看结果(两种方法):(http请求返回的数据格式:json、xml、html)

  1、res=req.text         #三种结果都可以返回

  2、res=req.json()      #json只能返回结果是json格式的

 

 

我们也可以通过session方式传值:(只能传入1个参数)

s=requests.session               #用一个s来接收返回的结果,以后我们在进行请求时,都用s去传。

pay_response=s.get(参数1,params=参数2)   

 

 

 那么,理解上述的知识后,我们用函数及参数化,就可以做这个简单的接口测试了。

首先,创建好我们的测试用例:以下边这个表格为例(注:写测试用例时,返回结果及比对结果为空)。

<span role="heading" aria-level="2">Python 3 读取和存储Excel数据(应用到接口测试)

 

然后,通过我们的pycharm写入执行用例的代码,就可以妥妥的做接口测试啦。

 

#Python读取Excel数据的函数方法:

 

from openpyxl import load_workbook

def demo_excel(file_name,sheet_name,start,end):

  open_wb=load_workbook(file_name)

  sheet=open_wb[sheet_name]

  data_list=[]

  for i in range(start,end):

    data_dict={}

    data_dict[‘ID’]=sheet.cell(i,1).value

    data_dict[‘TITLE’]=sheet.cell(i,2).value

    data_dict[‘METHOD’]=sheet.cell(i,3).value

    data_dict[‘URL’]=sheet.cell(i,4).value

    data_dict[‘DATA’]=sheet.cell(i,5).value

    data_dict[‘CODE’]=sheet.cell(i,6).value

    data_list.append(data_dict)

  return data_list

t=demo_excel(‘demo_excel.xlsx’,’Sheet1′,2,6)

 

 #发起http请求的函数方法:

 

import requests

cookie=None

def http_request(req_url,req_data,method):

  global cookie

  if method==’get’:

    response=requests.get(req_url,req_data,cookies=cookie)

  else:

    response=requests.post(req_url,req_data,cookies=cookie)

  if response.cookies!={}:

    cookie=response.cookies

  result=response.text()

  return result

 

 #执行测试用例:

 

open_wb=load_workbook(‘demo_excel.xlsx’)

sheet=open_wb[‘Sheet1’]

for item in t:

  print(‘正在执行第{0}条用例:{1}’.format(item[‘ID’],item[‘TITLE’]))

  url=item[‘URL’]

  data=item[‘DATA’]

  method=item[‘METHOD’]

  result=http_request(url,eval(data),method)

  print(result)

 

#返回结果:

  sheet.cell(item[‘ID’]+1,7).value=str(result)

#结果比对:

  if result[‘code’]==str(item[‘CODE’]):

    RESULT=’PASS’

  else:

    RESULT=’FAIL’

  sheet.cell(item[‘ID’]+1,8).value=RESULT

open_wb.save(‘demo_excel.xlsx’)

    

 

  

 

 

  

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155958.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 最好的频谱分析仪基础知识「建议收藏」

    最好的频谱分析仪基础知识「建议收藏」转载自网优雇佣军文章目录最好的频谱分析仪基础知识前言有两种技术方法可完成信号频域测量(统称为频谱分析)。快速傅立叶变换频谱分析仪扫频式频谱分析仪工作原理输入衰减器混频器中频滤波器对数放大器检波器视频滤波器扫描本振频谱分析仪关键性能指标频率分辨率相位噪声灵敏度总结一下提高频谱仪测试灵敏度的技术方法:最好的频谱分析仪基础知识前言频谱分析是观察和测量信号幅度和信号失真的一种快速方法,其显示结果可…

    2022年8月11日
    6
  • 完整的java项目_手把手搭建一个完整的javaweb项目

    完整的java项目_手把手搭建一个完整的javaweb项目手把手搭建一个完整的javaweb项目本案例使用Servlet+jsp制作,用MyEclipse和Mysql数据库进行搭建,详细介绍了搭建过程及知识点。下载地址:http://download.csdn.net/detail/qq_23994787/9904842点击下载主要功能有:1.用户注册2.用户登录3.用户列表展示4.用户信息修改5.用户信息删除涉及到的知识点有:1.JDBC2.Ser…

    2022年7月7日
    41
  • Center OS 7 下的安装Apache「建议收藏」

    Center OS 7 下的安装Apache「建议收藏」使用yum安装,直接yuminstallhttpd

    2026年2月5日
    4
  • hackbar功能简介

    hackbar功能简介SQL:提供三种数据库的sql查询语句,以及一些方便联合查询的语句XSS:提供xss攻击语句string.fromcharcode():将根据UNICODE值来输出xss语句htmlcharactor:将XSS语句转化为HTML字符实体(以&开头)alert(xss)statement:构建一条xss测…

    2022年5月18日
    74
  • thread count_ThreadPool

    thread count_ThreadPoolThreadPool类提供一个线程池,该线程池可用于发送工作项、处理异步I/O、代表其他线程等待以及处理计时器。许多应用程序创建的线程都要在休眠状态中消耗大量时间,以等待事件发生。其他线程可能进入休眠状态,只被定期唤醒以轮询更改或更新状态信息。线程池通过为应用程序提供一个由系统管理的辅助线程池使您可以更为有效地使用线程。一个线程监视排到线程池的若干个等待操作的状态。当一个等待操作

    2022年9月24日
    5
  • navicate premium 15 激活码【2021免费激活】「建议收藏」

    (navicate premium 15 激活码)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlMLZPB5EL5Q-eyJsaWNlbnNlSW…

    2022年3月21日
    353

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号