python request接口测试笔记(1)
python request接口测试笔记(1)
涉及到的功能说明:
- 需要登录拿到token,才能进行下一个接口的请求
- 读取csv文件中的信息,作为接口的参数
- 将接口响应结果,写入csv文件,以便分析统计
# -*- coding:utf-8 -*-
'''
author:***cy
time:2019-08-28
主要功能说明:
1、获取登录接口的token
2、接入食物识别的接口,批量测试食物识别模型,得出模型的正确率
'''
import requests
import json
import csv
class FoodDetect():
def __init__(self):
print("----------------start----------------")
'''获取token'''
def login_token(self):
# 初始化登录接口
login_url = 'https://api.ty.com/oauth2/token?grant_type=password&sms_verify=true'
login_header = {"Authorization": "Basic T23DZZMfrrdFrTfdfR4esdFGrfrdfOjdmTFJyEmFmYzgxRDgwSfdfR="}
login_data = {
"username": "15012345678",
"password": "123456",
"appName": "ty",
"grant_type": "password",
"sms_verify": "true"
}
# 登录请求接口
r_login = requests.post(url=login_url, data=login_data, headers=login_header)
# 获取登录的响应报文
print(r_login.text)
# login_response = json.loads(r_login.text)
# 保存登录的token信息
# access_token = login_response['access_token']
token = r_login.json()['access_token']
print(token)
'''请求接口获取token值'''
return token
def detect_food(self):
# 初始化
food_flag_init = 0
food_error_init = 0
food_fail_init = 0
# 读取csv文件
with open('E:\\test\\ty\\food_detect_init.csv', 'r') as csvFile:
reader = csv.reader(csvFile)
print(type(reader))
next(reader)
for row in reader:
# 食物识别问答接口的请求参数msg
food_msg = {"msg": row[0]}
print(food_msg)
# 获取登录接口中的token
food_headers = {"Authorization": "Bearer " + self.login_token()}
# 食物识别接口url
food_url = 'https://api.ty.com/nlp/api/v1.0/food_detect'
# 食物识别模型接口请求
r_food = requests.post(url=food_url, data=food_msg, headers=food_headers)
# 获取响应报文
print(r_food.text)
# 转换响应结果为dict格式
food_response = json.loads(r_food.text)
# 判断响应结果是否为空,不为空,则获取cal_name和name的名称
if food_response:
print(food_response[0])
food_response_all = food_response[0]
food_response_all_one = food_response_all['properties']
# 获取cal_name的值
food_response_cal = food_response_all_one['cal_name']
food_response_name = food_response_all_one['name']
print("food的calname:" + food_response_cal)
#food_response_name
if food_response_cal == row[0]:
# 如果calname和输入的食物名称一致,则测试通过,写入food_py_success文件
"""
模型匹配的方法:先匹配name,然后和库里面的cal_name对比,这里需要修改一下判断条件
"""
food_flag_init = food_flag_init + 1
print("food匹配成功%d" %food_flag_init)
else:
fail_data = ['food_name','name','cal_name']
food_fail_init = food_fail_init + 1
print("food匹配错误%d" %food_fail_init)
with open('E:\\test\\ty\\food_detect_fail.csv','a+',encoding='utf-8-sig') as ff:
fail_data[0] = row[0]
fail_data[1] = food_response_name
fail_data[2] = food_response_cal
ff.write(','.join(fail_data))
ff.write('\n')
ff.close()
else:
food_error_init = food_error_init + 1
print("food匹配失败%d" % food_error_init)
# 将失败的食物name存在csv文件
error_data = ['name']
with open('E:\\test\\ty\\food_detect_error.csv','a+',encoding = 'utf-8-sig')as ef:
error_data[0] = row[0]
ef.write(','.join(error_data))
ef.write('\n')
ef.close()
# 写入csv文件
data_row = ['food_real_name', 'food_response_name','food_response_cal']
with open('E:\\test\\ty\\food_detect_py.csv','a+',encoding='utf-8-sig') as f:
# csv_write = csv.writer(f)
data_row[0] = row[0]
data_row[1] = food_response_name
data_row[2] = food_response_cal
# data_row = list(data_row)
# print(data_row)
f.write(','.join(data_row))
f.write("\n")
# f.write("\\n")
print("down")
f.close()
# 打印食物匹配结果
print("food匹配成功%d" % food_flag_init)
print("food匹配错误%d" % food_fail_init)
print("food匹配失败%d" % food_error_init)
csvFile.close()
if __name__ == '__main__':
fd = FoodDetect()
fd.detect_food()
食物检测接口的响应结果格式如下:
[
{
"properties":{
"cal_name":"苹果汁",
"type":"food",
"index":4,
"food_id":4342,
"kcal_unit_weight":53.56,
"name":"苹果汁",
"start_index":0,
"time_stamp":1567226386
},
"sub_properties":{
"grams":543,
"is_default":true,
"quantifier_id":54,
"quantity":1,
"unit":"瓶"
},
"type":"Entity"
}
]
所以这里想要获取响应结果中的cal_name,需要先获取properties,代码如下:
food_response_all = food_response[0]
food_response_all_one = food_response_all['properties']
# 获取cal_name的值
food_response_cal = food_response_all_one['cal_name']
整体下来,批量测试接口模型的工作就是这样,其中将接口返回结果写入csv时,需要注意要换行写入,而且使用写入的格式是'a'或'a+'追加模式。
python request接口测试笔记(1)的更多相关文章
- python request 接口测试get和post请求
开发IDE:pycharm python:2.7.10 get请求 # coding: UTF-8 #兼容中文字符,如果没有这句,程序中有中文字符时,运行会报错 import requests #引用 ...
- Python + request接口测试中Cookie和Session的获取和使用
Cookie和Session的简单理解 由于Http协议是无状态的,所以产生了cookie和session进行状态的管理. 从哪里来,在哪里,到哪里去: --> Cookie是由服务端生成,存 ...
- python+request接口自动化框架
python+request接口自动化框架搭建 1.数据准备2.用python获取Excel文件中测试用例数据3.通过requests测试接口4.根据接口返回的code值和Excel对比 但本章只讲整 ...
- Python网络爬虫笔记(五):下载、分析京东P20销售数据
(一) 分析网页 下载下面这个链接的销售数据 https://item.jd.com/6733026.html#comment 1. 翻页的时候,谷歌F12的Network页签可以看到下面 ...
- 【转】基于Python的接口测试框架实例
下面小编就为大家带来一篇基于Python的接口测试框架实例.小编觉得挺不错的,现在就分享给大家,也给大家做个参考.一起跟随小编过来看看吧 背景 最近公司在做消息推送,那么自然就会产生很多接口,测试 ...
- 阅读OReilly.Web.Scraping.with.Python.2015.6笔记---Crawl
阅读OReilly.Web.Scraping.with.Python.2015.6笔记---Crawl 1.函数调用它自身,这样就形成了一个循环,一环套一环: from urllib.request ...
- 阅读OReilly.Web.Scraping.with.Python.2015.6笔记---找出网页中所有的href
阅读OReilly.Web.Scraping.with.Python.2015.6笔记---找出网页中所有的href 1.查找以<a>开头的所有文本,然后判断href是否在<a> ...
- 阅读OReilly.Web.Scraping.with.Python.2015.6笔记---BeautifulSoup---findAll
阅读OReilly.Web.Scraping.with.Python.2015.6笔记---BeautifulSoup---findAll 1..BeautifulSoup库的使用 Beautiful ...
- 基于Python的接口测试框架实例
文章来源:http://www.jb51.net/article/96481.htm 下面小编就为大家带来一篇基于Python的接口测试框架实例.小编觉得挺不错的,现在就分享给大家,也给大家做个参考. ...
随机推荐
- tar 命令详解(持续更新)
可以用man tar查看tar命令使用的权威解释 Main operation mode: -c: 建立压缩档案 -r:向压缩归档文件末尾追加文件 -t:查看内容 -u:更新原压缩包中的文件 -x:解 ...
- apache httpd多后缀解析漏洞复现
apache httpd多后缀解析漏洞复现 一.漏洞描述 Apache Httpd支持一个文件拥有多个后缀,不同的后缀执行不同的命令,也就是说当我们上传的文件中只要后缀名含有php,该文件就可以被解析 ...
- Linux 下实践 VxLAN
本文首发于我的公众号 Linux云计算网络(id: cloud_dev),专注于干货分享,号内有 10T 书籍和视频资源,后台回复 「1024」 即可领取,欢迎大家关注,二维码文末可以扫. 来源:ht ...
- Jquery第一次考核
1. 什么是JS JavaScript 缩写.一种计算机脚本语言 JavaScript是一种动态.弱类型.基于原型的语言,通过浏览器可以直接执行 2. JS三大组成部件 ECMAScript DOM ...
- 爬虫获取搜狐汽车的配置信息 和swf动态图表的销量数据-------详细教学
前情提要:需要爬取搜狐汽车的所有配置信息,具体配置对应的参数. 以及在动态图表上的历史销量. 比如: 一汽奥迪旗下Q5L 的<40 TFSI 荣享进取型 国VI >的历史销量和该配置的参数 ...
- win10 我的电脑下面的六个文件夹的隐藏
第一步 第二步 第三步 修改注册表,要隐藏那个文件夹,ThisPCPolicy 改为 "Hide" 修改我的文档的注册表值,使我的文档文件夹隐藏 <w ...
- JavaWeb——JSP开发1
1.什么是jsp,为什么要使用jsp. 再使用idea创建完一个web工程后,在webapp目录下会生成一个index.jsp 直接编译运行,网站将自动打开这样一个网页: 所以我们可以推测这个inde ...
- 基于RBAC的权限框架
RBAC权限框架(Role-Based Access Control)基于角色的权限访问控制的框架,通过用户-角色-权限的关联,非常方便的进行权限管理,在这里不再说明什么是RBAC,请自行百度. 谢谢 ...
- Django2.2中间件详解
中间件是 Django 用来处理请求和响应的钩子框架.它是一个轻量级的.底层级的"插件"系统,用于全局性地控制Django 的输入或输出,可以理解为内置的app或者小框架. 在dj ...
- Java中使用RestFul接口上传图片到阿里云OSS服务器
1.接口方法 import java.io.IOException; import javax.servlet.http.HttpServletRequest; import org.springfr ...