Jmespath JSON过滤器具有多个匹配项



我有一个看起来像这样的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的其他键值(示例,可以是VPC-ID的任何列表)

我可以使用Jmespath Filter获得Blabla1

Vpcs[?VpcId=='blabla1'].OtherKey

但是我找不到多个值的语法?我尝试过或语法||和复合语法|但是两个都可以吗? - 有关我尝试过的事情,请参见下面。

 Vpcs[?VpcId=='blabla1' || 'blabla1'].OtherKey
 Vpcs[?VpcId=='blabla1' || ?VpcId=='blabla1'].OtherKey
 Vpcs[(?VpcId=='blabla1') || (?VpcId=='blabla1')].OtherKey
 Vpcs[?VpcId=='blabla1' | ?VpcId=='blabla1'].OtherKey

有什么建议吗?这是可能的还是我必须一次收集一个结果并重组我想要的结果?

多个的一般语法为 [? expr1 || expr2],因此在您的情况下,您可以使用:

Vpcs[?VpcId=='vpc-blabla1' || VpcId=='vpc-blabla2'].OtherKey

另一个选项,如果您要搜索许多VPC ID,也可以说:

Vpcs[?contains(`["vpc-blabla1", "vpc-blabla2"]`, VpcId)].OtherKey

最新更新