如何使用带有JMESPath的嵌套json的数组中的值进行过滤?

时间:2020-08-31 21:00:33

标签: json jmespath

我有这个:

{
Item: [
        {
         key1: 'one',
         key2: 'two',
         key3: ["Sam", "Jack"]
        },
        {
         key1: 'one',
         key2: 'two',
         key3: ["Annie", "Jason"]
        }
     ]
}

因此,我想获取其key3包含"Annie"的对象。 我想出的最佳表达Items[].key3[?contain(@, 'Annie') == 'true']无效。

2 个答案:

答案 0 :(得分:0)

我认为您在,key1之后缺少逗号(key2)。

使用javascript:

jsonObject= {
  Item: [
    {
      key1: 'one',
      key2: 'two',
      key3: ["Sam", "Jack"]
    },
    {
      key1: 'one',
      key2: 'two',
      key3: ["Annie", "Jason"]
    }
  ]
};

console.log(
  jsonObject.Item.filter(item=>item.key3.includes("Annie"))
);

答案 1 :(得分:0)

在我看来,您有多种错别字,而且JMESPath表达式中有一个大问题。

首先,要使您的JSON完全有效:

  1. 您应该使用双引号,而不是单引号
  2. 您的名字也应该用双引号引起来

来源:https://restfulapi.net/json-syntax/

因此,这是您正确的JSON数据:

{
  "Item": [
    {
      "key1": "one",
      "key2": "two",
      "key3": [
        "Sam",
        "Jack"
      ]
    },
    {
      "key1": "one",
      "key2": "two",
      "key3": [
        "Annie",
        "Jason"
      ]
    }
  ]
}

然后,在您的JMESPath中,您有两种错别字:

  1. 您的顶级名称是Item而不是Items
  2. 正确的JMESPath表达式是contains而不是contain

最后,但最重要的问题也许是您的contains表达式不正确,它会在contains does return a boolean true or false时针对字符串 'true'测试包含的返回。

因此,您必须比较containsraw string literal `true`的收益。

因此您的正确查询最终将是:

Item[].key3[?contains(@, `Annie`) == `true`]

哪个给:

[
  [],
  [
    "Annie"
  ]
]
相关问题