gpt4 book ai didi

json - 具有多个匹配项的 JMESPath JSON 过滤器

转载 作者:行者123 更新时间:2023-12-04 10:03:20 24 4
gpt4 key购买 nike

我有一个 json block ,看起来有点像这样(你从 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

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

最佳答案

multiple 的一般语法是 [?表达式1 || expr2] 所以在你的情况下,你可以使用:

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

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

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

关于json - 具有多个匹配项的 JMESPath JSON 过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37945318/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com