我有一个看起来有点像这样的json块(你猜到了AWS)
{ "Vpcs":[
{
"VpcId":"vpc-blabla1",
"OtherKey":"Value"
},
{
"VpcId":"vpc-blabla2",
"OtherKey":"Value"
},
{
"VpcId":"vpc-blabla3",
"OtherKey":"Value"
},
{
"VpcId":"vpc-blabla4",
"OtherKey":"Value"
}]
}
我想使用JMESPath获取vpc-blabla1和vpc-blabla3的OtherKey值(示例,可以是任何vpc-id列表)
我可以使用JMESpath过滤器获取blabla1
Vpcs[?VpcId=='blabla1'].OtherKey
但是我找不到多个值的语法?我试过了Or语法||和复合语法|但都不起作用? - 请参阅下面我尝试过的事情。
Vpcs[?VpcId=='blabla1' || 'blabla1'].OtherKey
Vpcs[?VpcId=='blabla1' || ?VpcId=='blabla1'].OtherKey
Vpcs[(?VpcId=='blabla1') || (?VpcId=='blabla1')].OtherKey
Vpcs[?VpcId=='blabla1' | ?VpcId=='blabla1'].OtherKey
有什么建议吗?这是可能的,还是我必须一次收集一个结果集并重新组合我想要的结果?
答案 0 :(得分:13)
multiple的一般语法是[? expr1 || expr2
]所以在你的情况下,你可以使用:
Vpcs[?VpcId=='vpc-blabla1' || VpcId=='vpc-blabla2'].OtherKey
另一种选择,如果您有许多您正在搜索的VPC ID,您也可以说:
Vpcs[?contains(`["vpc-blabla1", "vpc-blabla2"]`, VpcId)].OtherKey