首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用循环过滤嵌套字典列表

使用循环过滤嵌套字典列表
EN

Stack Overflow用户
提问于 2021-05-24 00:31:53
回答 1查看 36关注 0票数 0

我有一个像下面这样的字典列表。

它的结构类似于树,其中每个节点都有任意数量的子节点。我希望选择具有作为输入提供的匹配“name”的节点。

代码语言:javascript
复制
newdata = [
    {'name':"Oli Bob", 'location':"United Kingdom", '_children':[
        {'name':"Mary May", 'location':"Germany"},
        {'name':"Christine Lobowski", 'location':"France"},
        {'name':"Brendon Philips", 'location':"USA",'_children':[
            {'name':"Margret Marmajuke", 'location':"Canada"},
            {'name':"Frank Harbours", 'location':"Russia",'_children':[{'name':"Todd Philips", 'location':"United Kingdom"}]},
        ]},
    ]},
    {'name':"Jamie Newhart", 'location':"India"},
    {'name':"Gemma Jane", 'location':"China", '_children':[
        {'name':"Emily Sykes", 'location':"South Korea"},
    ]},
    {'name':"James Newman", 'location':"Japan"},
]

目前我正在做这件事,使用下面的

代码语言:javascript
复制
op = []

def getInfo(list_of_dict, name):
    for dict1 in list_of_dict:
        if dict1["name"]==name:
            op.append(dict1)
        if "_children" in dict1:
            getInfo(dict1["_children"], name)

getInfo(newdata, "Gemma Jane")  
print(op)

我想在没有外部变量(List)的情况下执行相同的操作。

当我尝试使用下面的函数做同样的事情时

代码语言:javascript
复制
def getInfo(list_of_dict, name):
    for dict1 in list_of_dict:
        if dict1["name"]==name:
            return dict1
        if "_children" in dict1:
            return getInfo(dict1["_children"], name)

op = getInfo(newdata, "James Newman")  

它进入一个递归循环,并不能为所有的值提供正确的输出。

有什么建议来解决这个问题吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-05-24 00:39:47

您可以使用递归生成器函数来搜索节点。例如:

代码语言:javascript
复制
def getInfo(data, name):
    if isinstance(data, list):
        for value in data:
            yield from getInfo(value, name)
    elif isinstance(data, dict):
        if data.get("name") == name:
            yield data
        yield from getInfo(data.get("_children"), name)


for node in getInfo(newdata, "Gemma Jane"):
    print(node)

打印:

代码语言:javascript
复制
{'name': 'Gemma Jane', 'location': 'China', '_children': [{'name': 'Emily Sykes', 'location': 'South Korea'}]}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67662039

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档