
在接口自动化测试中,我们经常需要从 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