jmespath搜索嵌套数组问题

jmespath search nested array issue

我需要使用 jmespath

搜索嵌套数组中的所有字典,如下所示
my_list = [[{'age': 1, 'name': 'kobe'}, {'age': 2, 'name': 'james'}], [{'age': 3, 'name': 'kobe'}]]

我用 jmespath 搜索得到一个空列表:jmespath.search("[][?name=='kobe']", my_list)

如何获得结果:[{'age': 1, 'name': 'kobe'}, {'age': 3, 'name': 'kobe'}] 使用 jmespath 搜索

使用下面的代码:

my_list = [[{'age': 1, 'name': 'kobe'}, {'age': 2, 'name': 'james'}], [{'age': 3, 
'name': 'kobe'}]]

for l in my_list:
    for dictionary in l:
        Value_List = dictionary.values()
        if "kobe" in Value_List:
            print(dictionary)

输出:

{'age': 1, 'name': 'kobe'}
{'age': 3, 'name': 'kobe'}

或-----

my_list = [[{'age': 1, 'name': 'kobe'}, {'age': 2, 'name': 'james'}], 
          [{'age': 3, 'name': 'kobe'}]]
Match_List = []
for l in my_list:
    for dictionary in l:
        if dictionary["name"] == "kobe":
            Match_List.append(dictionary)
print(Match_List)

输出:

[{'age': 1, 'name': 'kobe'}, {'age': 3, 'name': 'kobe'}]

使用以下 jmesQuery:

[]|[?name=='kobe']

输入:

[[{"age": 1, "name": "kobe"}, {"age": 2, "name": "james"}], [{"age": 3, "name": "kobe"}]]

获取输出:

[
  {
    "age": 1,
    "name": "kobe"
  },
  {
    "age": 3,
    "name": "kobe"
  }
]

这里的问题是你混合了不同的类型,这就是你得不到预期结果的原因。

你应该做的是:

jmespath.search("[].to_array(@)[?name=='kobe'][]", my_list)

这里是使用Python控制台的分解(注意:

>>> my_list
[[{'age': 1, 'name': 'kobe'}, {'age': 2, 'name': 'james'}], [{'age': 3, 'name': 'kobe'}]]

>>> jmespath.search("[]", my_list)
[{'age': 1, 'name': 'kobe'}, {'age': 2, 'name': 'james'}, {'age': 3, 'name': 'kobe'}]

>>> jmespath.search("[].to_array(@)", my_list)
[[{'age': 1, 'name': 'kobe'}], [{'age': 2, 'name': 'james'}], [{'age': 3, 'name': 'kobe'}]]

>>> jmespath.search("[].to_array(@)[]", my_list)
[{'age': 1, 'name': 'kobe'}, {'age': 2, 'name': 'james'}, {'age': 3, 'name': 'kobe'}]

>>> jmespath.search("[].to_array(@)[?name=='kobe']", my_list)
[[{'age': 1, 'name': 'kobe'}], [], [{'age': 3, 'name': 'kobe'}]]

>>> jmespath.search("[].to_array(@)[?name=='kobe'][]", my_list)
[{'age': 1, 'name': 'kobe'}, {'age': 3, 'name': 'kobe'}]

您可以在本指南中通过示例找到更多解释:https://www.doaws.pl/blog/2021-12-05-how-to-master-aws-cli-in-15-minutes/how-to-master-aws-cli-in-15-minutes