问题描述
我正在尝试使用JSONPath基于包含@符号的键获取值失败。
原因:由于@是当前对象/元素,因此json不返回该值。
示例1:
{
"firstName": "John","lastName" : "doe","phoneNumbers": [
{
"type" : "iPhone","number": "0123-4567-8888"
},{
"type" : "home","number": "0123-4567-8910"
}
]
}
这有效:$.phoneNumbers[1].type
这有效:$.phoneNumbers[?(@.type=="iPhone")].type
样本2:
{
"firstName": "John","phoneNumbers": [
{
"@type" : "iPhone",{
"@type" : "home","number": "0123-4567-8910"
}
]
}
这有效:$.phoneNumbers[1].type
这不起作用: $.phoneNumbers[?(@.@type=="iPhone")].type
关于处理包含@
个字符的键和值的任何建议吗?
解决方法
这取决于您所使用的jsonpath实现。
如果您使用的是JsonPath-Plus,则可以尝试以下操作:
$.phoneNumbers[?(@['@type'] == "iPhone")]
您可以在线here评估基于JsonPath-Plus
的jsonpath。