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

Posted

技术标签:

【中文标题】具有多个匹配项的 JMESPath JSON 过滤器【英文标题】:JMESPath JSON filter with multiple matches 【发布时间】:2016-10-23 01:18:50 【问题描述】:

我有一个看起来有点像这样的 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

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

【问题讨论】:

【参考方案1】:

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

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

另一种选择,如果您要搜索多个 VPC id,您也可以说:

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

【讨论】:

优秀。我是如此接近,我只是无法在文档中看到答案。

以上是关于具有多个匹配项的 JMESPath JSON 过滤器的主要内容,如果未能解决你的问题,请参考以下文章

按属性过滤对象并使用 jmespath 中的键进行选择

fluentd:多个过滤器和匹配项的一个来源

针对另一个表达式的JSONPath或JMESPath过滤

将多个具有相似匹配项的 XSLT 模板组合起来

在使用 Selenium webdriver 时,为啥我们使用链表来收集具有多个匹配项的链接或下拉内容?

使用 awk sub 以数字方式为字符串添加前缀而不更改计数状态最多 5 个匹配“在每行具有多个匹配项的文本文件中”