JSONPath,其中键或值以@字符开头?

问题描述

我正在尝试使用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。