2025年3月5日 星期三 甲辰(龙)年 月初四 设为首页 加入收藏
rss
您当前的位置:首页 > 计算机 > 编程开发 > Python

Python3之返回GET和POST接口指定参数

时间:05-20来源:作者:点击数:39

接口是测试过程中必不可少的东西,有些参数,我们可以直接通过访问接口获取,例如总条数,某一个数据的名称、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)
  • 这里需要筛选什么参数,自己根据前面的筛选就好了哈,笔者就不写了(手动狗头)
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门