JsonPath:如何通过JsonPath检查字段是否有某些值?

Sau*_*til 3 json jsonpath

我发现有点难以理解如何编写一个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"
    }
  ]
}
Run Code Online (Sandbox Code Playgroud)

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

它给了我这个结果:

'0' ...
  'type' => "iPhone"
  'number' => "0123-4567-8888"
'1' ...
  'type' => "home"
  'number' => "0123-4567-8910"
Run Code Online (Sandbox Code Playgroud)

我这样做了:http://jsonpath.com/

因此,如果我想知道在phonenumber中的数字字段中是否有任何值,或者它是否为空,那么我的jsonpath应该是什么?我尝试了各种各样的东西,但无法理解.

谢谢!

mko*_*gen 7

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

$.phoneNumbers[?(@.number)].number
Run Code Online (Sandbox Code Playgroud)

这将为您提供任何非空值的数字,即

"phoneNumbers": [
{
  "type"  : "iPhone",
  "number": "0123-4567-8888"
},
{
  "type"  : "home",
  "number": ""
}]
Run Code Online (Sandbox Code Playgroud)

只返回第一个结果

'0' => "0123-4567-8888"
Run Code Online (Sandbox Code Playgroud)

无论number-field是完全缺失null还是空字符串"".

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