在接口自动化测试中,我们经常需要从 JSON 响应中提取特定条件下的数据。一个典型场景是:查询合同列表,找出所有“收款合同-01-变更”的记录,然后取最后一个(通常是最新或最完整的)合同编号,用于后续上传附件或更新操作。
JMeter 提供了 JSON 提取器(JSON Path Extractor) 来解析响应并提取字段。然而,当筛选条件返回多个结果时,如何稳定、准确地获取“最后一个”并非一目了然。本文将深入探讨几种实现方式,分析各自的优缺点,并给出经过实践检验的最佳方案。
一、常见需求与示例数据
假设接口返回的 JSON 结构如下(data 数组包含多个合同对象):
json
{
"status": 200,
"msg": "查询成功",
"data": [
{"CODE": "001", "PROJECT_NAME": "测试001"},
{"CODE": "002", "PROJECT_NAME": "测试001"},
{"CODE": "003", "PROJECT_NAME": "测试合同1"},
{"CODE": "004", "PROJECT_NAME": "收款合同-01-变更"},
{"CODE": "005", "PROJECT_NAME": "收款合同-08"},
{"CODE": "006", "PROJECT_NAME": "收款合同-01-变更"},
{"CODE": "007", "PROJECT_NAME": "收款合同-01-变更"},
{"CODE": "008", "PROJECT_NAME": "收款合同-01-变更"}
]
}
我们想要提取 PROJECT_NAME 为“收款合同-01-变更”的所有记录中的最后一个 CODE,即 "008"。
二、方法一:直接使用 JSONPath 负索引 [-1]
在 JSONPath 标准语法中,[-1] 表示数组的最后一个元素。因此,一个直观的写法是:
json
$.data[?(@.PROJECT_NAME=='收款合同-01-变更')][-1].CODE
优点:
-
表达式简洁直观。
-
在其他 JSONPath 实现(如 Java 的 Jayway、Python 的 jsonpath-ng)中通常可以正常工作。
缺点/限制:
-
JM

1万+

被折叠的 条评论
为什么被折叠?



