接口是测试过程中必不可少的东西,有些参数,我们可以直接通过访问接口获取,例如总条数,某一个数据的名称、ID之类的信息;但是我们需要批量获取某一个字段的信息呢,而这时候,接口又不支持筛选参数,该怎么呢?python可以帮到你,当然其他语言也是可以哒!下面开始吧...
第一种:GET接口筛选指定返回参数
# -*- coding:utf-8 -*-
#惯例,先导入包
import json
import urllib.request
# 测试的url:这里怼一个假的url,自行替换哈
url=https://www.testurl.com?name=zhangsan&grade=大一
#访问接口,模拟在postman访问接口
response = urllib.request.urlopen(url)
#请求返回的东西,python不认识,所以我们要进行转码
#将已编码的 JSON 字符串解码为 Python 对象
html = json.loads(response.read())
# 可以打印出来看看,与postman访问是一致的
print(html)
返回的数据大概长这个样子↓↓↓
ok,这个时候,我们如果需要统计接口返回的Comments字段的所有总和,有上千上万条数据,该怎么做呢,难道手动一个一个加?不存在的,下面继续
接上上面的代码
#我们先试一下获取第一个的Comments字段的数值,成功之后,加个循环函数,就可以统计全部,完美!
print(html['results'][0]['Comments'])
# 然后我们设置一下待会循环的返回,记得是从0开始哦,我们就取接口所返回的数据条数作为取值范围即可,可以要转换为int类型哦!
total = int(html['total'])
i = 0
sum = 0 #这个是总和数
# 笔者这里使用一个while循环进行演示,也可以使用其他循环函数哈
while i < total:
sum = sum + int(html['results'][i]['Comments'])
# 输出结果 总数:52
print("总数:",sum)
第二种:POST(x-www-form-urlencoded)接口筛选指定返回参数
在postman上接口的访问格式是这样子的↓↓↓
返回的结果这样子↓↓↓
问题:在返回的数据中,部分数据的Size缺失,如何把Size缺失的数据挑选出来,并返回对应的唯一标识ID以及统计总数?show time!
# -*- coding:utf-8 -*-
#惯例,先导入包
import json
import urllib.request
from urllib import parse
# 测试的url:这里怼一个假的url,自行替换哈
url=https://www.testurl.com
# 怼上请求头
headerdata = {"Content-Type": "application/x-www-form-urlencoded"}
# 怼上入参
test_data ={'name':'zhangsan','grade':'大一'}
# 我们设置到的入参为字符串类型的dict,但是python无法识别,需要先转码为字节类型
test_data_urlencode = urllib.parse.urlencode(test_data).encode(encoding='UTF8')
print(type(test_data), type(test_data_urlencode)) # 输出为:<class 'dict'> <class 'bytes'>
# 发送请求参数
response = urllib.request.Request(url, test_data_urlencode, headerdata)
#将已编码的 JSON 字符串解码为 Python 对象
html = json.loads(urllib.request.urlopen(response).read().decode('utf-8'))
#设定取值范围
total = int(html['total'])
sum0 = 0
sum1 = 0
for i in range(100):
if 'Size' in html['results'][i]: #判断每条数据里面是否存在Size字段,需要判断字段参数是否为空,可以使用if Size is False
sum0 =sum0 + i # 如果存在,返回总数
else:
print(i, html['results'][i]['ID']) #如果不存在,返回其对应的ID
sum1 =sum1 + i #如果不存在,返回总数
print(sum0,sum1)
第三种:POST(json)接口筛选指定返回参数
# -*- coding:utf-8 -*-
#惯例,先导入包
import json
import urllib.request
# 测试的url:这里怼一个假的url,自行替换哈
url=https://www.testurl.com
# 请求头
header = {"Content-Type": "application/json"}
# 入参
value ={"name":"zhangsan","grade":"大一"}
# 把入参进行json格式的编码
data = json.dumps(value)
# data出来的是字符串格式,需要转换成字节格式,传参只能接受字节格式
datas = bytes(data, 'utf-8')
# 请求接口
response = urllib.request.Request(url, datas, header)
# 将已编码的 JSON 字符串解码为 Python 对象
html = json.loads(urllib.request.urlopen(response).read().decode('utf-8'))
print(html)
这里需要筛选什么参数,自己根据前面的筛选就好了哈,笔者就不写了(手动狗头)