我需要用jmespath搜索嵌套数组中的所有字典,如下所示
my_list = [[{'age': 1, 'name': 'kobe'}, {'age': 2, 'name': 'james'}], [{'age': 3, 'name': 'kobe'}]]我用jmespath搜索得到了一个空列表:jmespath.search("[][?name=='kobe']", my_list)
如何使用jmespath搜索获得result:[{'age': 1, 'name': 'kobe'}, {'age': 3, 'name': 'kobe'}]
发布于 2019-02-12 20:53:50
使用以下jmesQuery:
[]|[?name=='kobe']在输入时:
[[{"age": 1, "name": "kobe"}, {"age": 2, "name": "james"}], [{"age": 3, "name": "kobe"}]]要获取输出,请执行以下操作:
[
{
"age": 1,
"name": "kobe"
},
{
"age": 3,
"name": "kobe"
}
]发布于 2019-02-12 20:34:21
使用以下代码:
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'}]https://stackoverflow.com/questions/54650055
复制相似问题