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

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

如何从HTTPRunner响应中提取数据

在使用HTTPRunner工具时,提取响应数据是非常重要的一步操作。以下将详细介绍如何从返回的JSON数据中提取所需的各种数据。

1. 理解content对象

在HTTPRunner中,content对象实际上是请求返回的响应内容。在Python中,这个对象通常会返回原始的字节类型(byte)。为了方便提取数据,我们可以将其转换为字典类型。以下是一个示例响应:

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

将其转换为Python字典后,可以通过以下方式提取数据:

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

2. 列表类型的数据提取

如果返回的数据是列表类型,例如以下结构:

[    {        "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"    }]

可以通过以下方式提取数据:

  • content.0 提取列表中的第一组数据:{"age": 20, "create_time": "2019-09-15", "id": 1, "mail": "283340479@qq.com", "name": "yoyo", "sex": "M"}
  • content.1 提取列表中的第二组数据:{"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 对应值的第三个字符 "y",可以使用 content.0.name[2]

3. 实践案例

以下是一个实际案例,展示如何从响应数据中提取所需数据。假设通过HTTPRunner发起一个GET请求,返回的响应内容如下:

{    "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.ymlconfig:    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    validate:        - eq: [status_code, 200]        - eq: [content.msg, success!]        - eq: [$mail, 283340479@qq.com]

运行上述脚本后,会从响应中提取 mail 对应的值 "283340479@qq.com",并验证响应状态码、消息内容以及提取结果。

4. 提取方法总结

总结来说,content 对象的提取方法有两种:

  • content.key:直接通过键名访问对应值。
  • content.int:用于访问列表中的具体项。
  • 通过层级一层一层地查找,可以轻松提取所需的数据。

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

    你可能感兴趣的文章
    php 运算符and or && || 的详解
    查看>>
    php 返回html字符串长度限制,记一次js中和php中的字符串长度计算截取的终极问题和完美...
    查看>>
    php 阿里云oss 上传回调
    查看>>
    PHP 面向对象 final类与final方法
    查看>>
    php+JQ+EasyUI自动加载数据
    查看>>
    php+sql server根据自增序号id区间查询第几条到第几条的数据
    查看>>
    php--------获取当前时间、时间戳
    查看>>
    Redis使用场景举例
    查看>>
    php--正则表达式
    查看>>
    php--防止sql注入的方法
    查看>>
    PHP-CGI Windows平台远程代码执行漏洞复现(CVE-2024-4577)
    查看>>
    php-cgi耗尽报502错误
    查看>>
    php-cgi(fpm-cgi) 进程 CPU 100% 与 file_get_content...
    查看>>
    PHP-DI/Invoker 开源项目使用教程
    查看>>
    php-fpm与Nginx运行常见错误说明
    查看>>
    php-fpm比php成为apache模块好在哪
    查看>>
    php-fpm超时时间设置request_terminate_timeout分析
    查看>>
    php-fpm进程数优化
    查看>>
    PHP-GD库-分类整理
    查看>>
    php-laravel框架用户验证(Auth)模块解析(一)
    查看>>