python利用Excel读取和存储测试数据完成接口自动化

 http_request2.py用于发起http请求

#读取多条测试用例
#1、导入requests模块
import  requests
#从 class_12_19.do_excel1导入read_data函数
from do_excel2 import read_data
from do_excel2 import write_data
from do_excel2 import count_case
#定义http请求函数

COOKIE=None

def http_request2(method,url,data):

    if  method=='get':
        print('发起一个get请求')
        result=requests.get(url,data,cookies=COOKIE)
    else:
        print('发起一个post请求')
        result=requests.post(url,data,cookies=COOKIE)
    return result   #返回响应体
   # return result.json()  #返回响应结果:结果是字典类型:{'status': 1, 'code': '10001', 'data': None, 'msg': '登录成功'}


#从Excel读取到多条测试数据
sheets=['login','recharge','withdraw']
for sheet1 in sheets:
    max_row=count_case(sheet1)
    print(max_row)
    for case_id in range(1,max_row):
        data=read_data(sheet1,case_id)
        print('读取到第{}条测试用例:'.format(data[0]))
        print('测试数据 ',data)
        #print(type(data[2]))
        #调用函数发起http请求
        result=http_request2(data[4],data[2],eval(data[3]))
        print('响应结果为 ',result.json())
        if result.cookies:
                COOKIE=result.cookies

            #将测试实际结果写入excel
            #write_data(case_id+1,6,result['code'])
        write_data(sheet1,case_id+1,7,str(result.json()))
        #对比测试结果和期望结果
        if result.json()['code']==str(data[5]):
            print('测试通过')
            #将用例执行结果写入Excel
            write_data(sheet1,case_id+1,8,'Pass')
        else:
            write_data(sheet1,case_id+1,8,'Fail')
            print('测试失败')
http_request2.py
do_excel2.py完成对excel中用例的读、写、统计
# 导入load_workbook
from openpyxl import load_workbook

#读取测试数据
#将excel中每一条测试用例读取到一个列表中

#读取一条测试用例——写到一个函数中
def read_data(sheet_name,case_id):
    # 打开excel
    workbook1=load_workbook('test_case2.xlsx')
    # 定位表单(test_data)
    sheet1=workbook1[sheet_name]
    print(sheet1)
    test_case=[]  #用来存储每一行数据,也就是一条测试用例
    test_case.append(sheet1.cell(case_id+1,1).value)
    test_case.append(sheet1.cell(case_id+1,2).value)
    test_case.append(sheet1.cell(case_id+1,3).value)
    test_case.append(sheet1.cell(case_id+1,4).value)
    test_case.append(sheet1.cell(case_id+1,5).value)
    test_case.append(sheet1.cell(case_id+1,6).value)
    return test_case    #将读取到的用例返回

#调用函数读取第1条测试用例,并将返回结果保存在data中
# data=read_data(1)
# print(data)

#将测试结果写会excel
def write_data(sheet_name,row,col,value):
    workbook1=load_workbook('test_case2.xlsx')
    sheet=workbook1[sheet_name]
    sheet.cell(row,col).value=value
    workbook1.save('test_case2.xlsx')


#统计测试用例的行数
def count_case(sheet_name):
     workbook1=load_workbook('test_case2.xlsx')
     sheet=workbook1[sheet_name]
     max_row=sheet.max_row  #统计测试用例的行数
     return max_row
do_excel2.py
test_case2.xlsx存储测试用例

 

posted @ 2018-12-18 18:34  YLG001  阅读(1097)  评论(0编辑  收藏  举报