Pet*_*utz 6 select json any jq
在jq的帮助下,我想选择属性列表中至少有一个required=true的节点的所有地址。结果列表应该有唯一的项目。
这是我的 Json:
{
"nodes": [
{
"address":"127.0.0.1",
"attributes": [
{
"id":"abc",
"required":true
},
{
"id":"def",
"required":true
},
{
"id":"ghi",
"required":false
}
]
},
{
"address":"127.0.0.2",
"attributes": [
{
"id":"abc",
"required":false
},
{
"id":"def",
"required":false
}
]
}
]
}
Run Code Online (Sandbox Code Playgroud)
我首先尝试:
jq '.nodes[] | select(.attributes[].required == true) | .address'
Run Code Online (Sandbox Code Playgroud)
这产生:
"127.0.0.1"
"127.0.0.1"
Run Code Online (Sandbox Code Playgroud)
因此,它获取在属性部分中找到的每个required=true字段的地址。如何使结果列表唯一?jq 中还有一个独特的关键字,但我不知道这对我有什么帮助。
使用unique是安全的,但它确实需要排序,这可能不是必需的。例如,在您的特定情况下,重复是 jq 查询的产物。考虑any改为使用(或也使用),因为它更准确地捕获了意图(“至少一个”),并且具有“短路”语义(即,一旦条件为真,它就会停止搜索):
$ jq '.nodes[]
| select( any(.attributes[]; .required == true))
| .address' input.json
Run Code Online (Sandbox Code Playgroud)
输出:
"127.0.0.1"
Run Code Online (Sandbox Code Playgroud)
unique如有必要,您可以随时添加。