博客
关于我
httprunner学习7-extract提取content返回对象
阅读量:471 次
发布时间:2019-03-06

本文共 3158 字,大约阅读时间需要 10 分钟。

前言

提取response返回的对象数据,用extract关键字。前面有关于token的取值,通过content.token取值。

本篇详细讲解如何从返回的json数据提取出想要的各种数据

content对象

httprunner里面的content实际上就是request里面的r.content,返回的是一个byte类型。

比如返回的json数据如下

{	"code": 0,	"msg": "login success!",	"username": "test",	"token": "b3f7e8e12d23591ea671374dee818c63b1599d4d"}

上面的json数据,可以转成python里面对应的dict类型,extract提取方法

  • content.code 取出code后面对应的值0
  • content.msg 取出msg后面的对应值"login success!"
  • content.username 取出username后面的值"test"
  • content.token 取出token后面的值"b3f7e8e12d23591ea671374dee818c63b1599d4d"

list类型取值

如果返回的json数据,转化成python里面的list对象,如下结构

[{		"age": 20,		"create_time": "2019-09-15",		"id": 1,		"mail": "283340479@qq.com",		"name": "yoyo",		"sex": "M"	},	{		"age": 21,		"create_time": "2019-09-16",		"id": 2,		"mail": "123445@qq.com",		"name": "yoyo111",		"sex": "M"	}]

上面这种转化成python里面的list对象,可以用content.int 方法取出对应下标的数据,对应的extract提取方法

  • content.0 取出list里面的第一组数据{"age": 20, "create_time": "2019-09-15", "id": 1, "mail": "283340479@qq.com", "name": "yoyo", "sex": "M"}
  • content.1 取出list里面的第二组数据{"age": 21, "create_time": "2019-09-16", "id": 2, "mail": "123445@qq.com", "name": "yoyo111", "sex": "M"}
  • content.0.name 取出第一组数据的name对应值"yoyo"
  • content.1.name 取出第二组数据的name对应的值"yoyo111"
  • content.0.mail 取出第一组数据的mail对应值"283340479@qq.com"

通过content.int的方法也可以取出字符串里面的值,比如我要取出第一组数据,name对应值"yoyo"里面的第三个字符,就可以用content.0.name.2,这种取字符串的一般很少用

实践案例

总的来说,content对象的取值就2种方式:content.keycontent.int,按层级一层的去查找就可以了

这里有个demo案例,使用httpie请求后的响应结果如下

C:\Users\dell>http http://127.0.0.1:8000/api/test/demoHTTP/1.1 200 OKContent-Length: 255Content-Type: application/jsonDate: Sun, 22 Sep 2019 10:11:07 GMTServer: WSGIServer/0.2 CPython/3.6.0X-Frame-Options: SAMEORIGIN{    "code": 0,    "datas": [        {            "age": 20,            "create_time": "2019-09-15",            "id": 1,            "mail": "283340479@qq.com",            "name": "yoyo",            "sex": "M"        },        {            "age": 21,            "create_time": "2019-09-16",            "id": 2,            "mail": "123445@qq.com",            "name": "yoyo111",            "sex": "M"        }    ],    "msg": "success!"}

目标:从响应的结果里面取除datas数据里面的一组数据mail对应的值283340479@qq.com,并断言。

test_demo.yml脚本内容

# 上海悠悠,QQ交流群:750815713- config:    name: test_demo    variables: {}- test:    name: test_demo case1    request:        url: http://127.0.0.1:8000/api/test/demo        method: GET        headers:            Content-Type: application/json            User-Agent: python-requests/2.18.4        json:            username: test            password: 123456    extract:        - mail: content.datas.0.mail         # 提取mail    validate:        - eq: [status_code, 200]        - eq: [content.msg, success!]        - eq: [$mail, 283340479@qq.com]

运行结果

D:\soft\untitled>hrun test_demo.ymltest_demo case1INFO     GET http://127.0.0.1:8000/api/test/demoINFO     status_code: 200, response_time(ms): 4.99 ms, response_length: 255 bytesINFO     start to extract from response object.INFO     start to validate..----------------------------------------------------------------------Ran 1 test in 0.012sOKINFO     Start to render Html report ...INFO     Generated Html report: D:\soft\untitled\reports\1569147460.html

运行成功!

转载地址:http://sxlbz.baihongyu.com/

你可能感兴趣的文章
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_实际操作_02---大数据之Nifi工作笔记0032
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>
NIFI大数据进阶_使用NIFI表达式语言_来获取自定义属性中的数据_NIFI表达式使用体验---大数据之Nifi工作笔记0024
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_内嵌ZK模式集群2_实际操作搭建NIFI内嵌模式集群---大数据之Nifi工作笔记0016
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>
NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_实际操作_03---大数据之Nifi工作笔记0035
查看>>
NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_01---大数据之Nifi工作笔记0033
查看>>
NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_02---大数据之Nifi工作笔记0034
查看>>