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)
后面考虑换种格式写接口测试用例,毕竟参数大部分都是需要复制的