我需要使用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搜索
答案 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"
}
]