Python+reuqests自动化接口测试

本文介绍使用Python结合requests库实现接口自动化测试的方法。包括从Excel读取测试用例、执行GET/POST请求并记录测试结果到Excel的过程。

原文转自:https://www.cnblogs.com/timer228/p/7904622.html

1.最近自己在摸索Python+reuqests自动化接口测试,要实现某个功能,首先自己得有清晰的逻辑思路!这样效率才会很快!

思路--1.通过python读取Excel中的接口用例,2.通过python的函数调用,get/Post 进行测试,3把测试结果写到一个新的Excel表格中!

1:编写接口测试用例数据,只是举了两个例子:

2.:函数方法  URl: 服务器地址,host:接口地址,type(请求类型:get或者post),data:参数

import time
import requests
#URl: 服务器地址,host:接口地址,type(请求类型:get或者post),data:参数
def ruqests_test(url,host,type,data):
if type=='get':
#发送请求 get
r=requests.get("%s%s" %(url,host),data=data)

return r

else :
        #发送请求 get 
r=requests.post("%s%s" %(url,host),data=data)
        return r



 3:读取Excel接口用例,调用函数发送请求,接收返回信息,写入Excel文档中

#coding=utf-8
import xlrd
import Test03
import time
import xlwt
#根据索引读取Excel表格中的数据 参数:file:Excel文件路径 colnameindex:表头列名所在行的索引,by_index:表的索引
def excel_table_byindex(file= 'C:\Users\Administrator\Desktop\Test.xlsx',colnameindex=0,by_index=0):
data =xlrd.open_workbook(file)
table = data.sheets()[by_index]
nrows = table.nrows #行数
ncols = table.ncols #列数
colnames = table.row_values(colnameindex) #某一行数据
list =[]
for rownum in range(1,nrows):

row = table.row_values(rownum)
if row:
app = {}
for i in range(len(colnames)):
app[colnames[i]] = row[i]
#print app[colnames[i]]
list.append(app)
return list
if __name__=="__main__":
tables = excel_table_byindex()
i = 1
wb = xlwt.Workbook() # 新建了一个新的工作表
sheet1 = wb.add_sheet('Sheet 1')
wb.add_sheet('Sheet 2')
#列表名称
row1 = sheet1.row(0)
row1.write(0, u'地址')
row1.write(1, u'状态码')
row1.write(2, u'返回信息')
row1.write(3, u'时间')
for row in tables:
#row['value1'] if row['value1'] == ''else int(row['value1']):三目运算,当读取的值为空,就不转换为int类型
        r=Test03.ruqests_test(row['url'],row['host'],row['type'],{row['key1']:row['value1'] if row['value1'] == ''else int(row['value1']),row['key2']:row['value2'] if row['value2'] == ''else int(row['value2'])})
row1 = sheet1.row(i)
row1.write(0, r.url)
row1.write(1, r.status_code)
row1.write(2, r.text)
row1.write(3,time .strftime("%Y-%m-%d %H:%M:%S", time.localtime()))
wb.save('C:\Users\Administrator\Desktop\Test00.xlsx')
i=i+1

结果如图所示:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值