python读取Excel中测试用例,接口接收不到参数的问题

python读取Excel中测试用例遇到的问题

遇到问题:
读取Excel中测试用例的时候,接口无法识别传参,报错400.

原因
python从Excel中读取的数据,都是字符串,而一般接口接受参数都是以json格式接收,所以我们需要把从Excel中读取的参数进行格式转换,转换成dict格式。

解决方案
具体可以使用json.loads()转换,转换后即可正常传参请求接口。
于是:

        if method == 'get':
            # Exel读出来的数据类型是字符串,而get请求的入参必须是字典类型,post请求的入参是json字符串类型
            print(params, type(params), len(params))
            ps = json.loads(params)
            print(ps)
            resp = requests.get(url, params=ps, headers=self.header, verify=False)

结果报错了:
报错信息
仔细看这个暴多是json转换报错了。说明params的格式是有问题的,于是我把params打印出来跟手写的字符串比较发现并没有任何差别。
最后,重新把Excel中的参数手动输入了一遍,解决。
原来测试用例中参数是我通过postman复制过来的,应该是格式有些问题,重新手动敲进去即可正确转换格式,转换以后可以正常传参
请求成成
顺便附带一个解决控制台输出warnings的问题

import urllib3
import api_auto_test.test_tools.readConfig as readConfig
# 解决Python3 控制台输出InsecureRequestWarning的问题
urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)

后面考虑换种格式写接口测试用例,毕竟参数大部分都是需要复制的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值