jmespath搜索嵌套数组问题

时间:2019-02-12 12:23:25

标签: python jmespath

我需要使用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搜索

2 个答案:

答案 0 :(得分:0)

使用以下代码:

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'}

OR -----

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'}]

答案 1 :(得分:0)

使用以下jmesQuery:

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

输入时:

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

获取输出:

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