JMeter JSON 提取器:如何提取匹配条件的最后一个值

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值