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

本文共 2688 字,大约阅读时间需要 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.yml
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
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/

    你可能感兴趣的文章
    notepad++最详情汇总
    查看>>
    notepad++正则表达式替换字符串详解
    查看>>
    notepad如何自动对齐_notepad++怎么自动排版
    查看>>
    Notes on Paul Irish's "Things I learned from the jQuery source" casts
    查看>>
    Notification 使用详解(很全
    查看>>
    NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
    查看>>
    NotImplementedError: Could not run torchvision::nms
    查看>>
    nova基于ubs机制扩展scheduler-filter
    查看>>
    Now trying to drop the old temporary tablespace, the session hangs.
    查看>>
    nowcoder—Beauty of Trees
    查看>>
    np.arange()和np.linspace()绘制logistic回归图像时得到不同的结果?
    查看>>
    np.power的使用
    查看>>
    NPM 2FA双重认证的设置方法
    查看>>
    npm build报错Cannot find module ‘html-webpack-plugin‘解决方法
    查看>>
    npm build报错Cannot find module ‘webpack/lib/rules/BasicEffectRulePlugin‘解决方法
    查看>>
    npm build报错Cannot find module ‘webpack‘解决方法
    查看>>