我发现很难理解如何编写jsonpath来告诉我该字段中是否存在某些值,这有点困难。

例如:考虑以下json:

{
  "firstName": "John",
  "lastName" : "doe",
  "age"      : 26,
  "address"  : {
    "streetAddress": "naist street",
    "city"         : "Nara",
    "postalCode"   : "630-0192"
  },
  "phoneNumbers": [
    {
      "type"  : "iPhone",
      "number": "0123-4567-8888"
    },
    {
      "type"  : "home",
      "number": "0123-4567-8910"
    }
  ]
}

如果我写:$ .phoneNumbers [?(@。type.length> 0)]

它给了我这个结果:
'0' ...
  'type' => "iPhone"
  'number' => "0123-4567-8888"
'1' ...
  'type' => "home"
  'number' => "0123-4567-8910"

我在这里做的:http://jsonpath.com/

所以,如果假设我想知道电话号码内的数字字段中是否有任何值,或者它是否为空,那么我的jsonpath应该是什么?我尝试了各种方法,但无法弄清楚。

谢谢!

最佳答案

您可以像这样使用exist-filter ?(@.<field>)

$.phoneNumbers[?(@.number)].number

这将为您提供所有具有非空值的数字,即
"phoneNumbers": [
{
  "type"  : "iPhone",
  "number": "0123-4567-8888"
},
{
  "type"  : "home",
  "number": ""
}]

只会返回第一个结果
'0' => "0123-4567-8888"

无论number -field是否完全丢失,null还是空字符串""

我从Newtonsoft.Json的JPath-Unit-Tests中学到了这一点,请参阅:JPathExecutTests.ExistsQuery()

关于json - JsonPath:如何通过JsonPath检查字段是否具有某些值?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/37876043/

10-15 04:18