Python+reuqests自动化接口测试

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
复制代码
结果如图所示:
复制代码
有什么不明白的可以留言!  希望可以帮到一些人!

Python接口自动化测试零基础入门到精通(2023最新版)

相关推荐
m0_736919102 小时前
C++代码风格检查工具
开发语言·c++·算法
喵手2 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
2501_944934732 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy2 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
黎雁·泠崖3 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
2301_763472464 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
肖永威4 小时前
macOS环境安装/卸载python实践笔记
笔记·python·macos
TechWJ4 小时前
PyPTO编程范式深度解读:让NPU开发像写Python一样简单
开发语言·python·cann·pypto
枷锁—sha4 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
abluckyboy4 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法