我发现有点难以理解如何编写一个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应该是什么?我尝试了各种各样的东西,但无法理解.
谢谢!
您可以?(@.<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()