我有一个如下所示的JSON文件:
{
"InstanceId": "i-9KwoRGF6jbhYdZi823aE4qN",
"Tags": [
{
"Key": "blah",
"Value": "server-blah"
},
{
"Key": "environment",
"Value": "ops"
},
{
"Key": "server_role",
"Value": "appserver"
},
{
"Key": "Name",
"Value": "some_name"
},
{
"Key": "product",
"Value": "some_server"
}
]
}
{
...more objects like the above...
}
我需要显示InstanceID,其中"key"=="Environment"和"Value"=="ops"。 我有JQ-1.6。
如果我说:
cat source.json | jq '
{ InstanceId, Tags } |
(.Tags[] | select( .Key == "environment" ))
'
我得到了一些我想要的,但我不知道如何在输出中包括InstanceID,也不知道如何合并SELECT的"and"部分。
我不确定这是否是您要查找的确切输出(如果不是请注明),但这将输出Tag
推荐答案对象的Tag
withKey
environment
和Value
ops
。
jq 'select( .Tags[] | (.Key == "environment" and .Value == "ops")) | .InstanceId' < source.json