gpt4 book ai didi

arrays - jsonpath 在与数组索引无关的 jsonarray 中查找字符串值

转载 作者:行者123 更新时间:2023-12-05 00:17:40 25 4
gpt4 key购买 nike

我有一个数组的 Gatling JSON 对象。该对象包含错误消息,例如

"error": [
{
"errorCode": "111",
"errorMessage": "very dynamic error :- at [Source: java.io.PushbackInputStream@5d0edb12; line: 6, column: 6]; nested exception is com.fasterxml.jackson.core.JsonParseException: "
},
{
"errorCode": null,
"errorMessage": "Fixed Error Message"
},
{
"errorCode": "112",
"errorMessage": "Again some error message"
}
]

我正在检查 jsonpath 作为
($.error[1].errorMessage).is("Fixed Error Message")
但是,不同的 API 有不同的错误对象,固定的 errorMessage 可以放在数组中的任何索引位置。

如何动态检查 jsonArray 中是否存在固定的 errorMessage 而不用担心 arrayIndex ?

我可以做一个独立匹配字符串与数组元素而不提及数组索引的查询,如下所示? ($.error[*].errorMessage).is("Fixed Error Message")

最佳答案

您可以使用以下内容过滤数组:

JsonPath.query("$.error[?(@.errorMessage=='Fixed Error Message')]", json)

编辑 1:

这将是检查是否确实找到消息的首选:
jsonPath("$.error[?(@.errorMessage=='Fixed Error Message')]").exists

如果您想做 .is() 检查,您可以尝试以下操作(不是很好):
jsonPath("$.error[?(@.errorMessage=='Fixed Error Message')].errorMessage").is("Fixed Error Message")

关于arrays - jsonpath 在与数组索引无关的 jsonarray 中查找字符串值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39584680/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com