加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

Python:如何通过叶值过滤n-nested dicts的dict?

发布时间:2020-12-16 22:05:22 所属栏目:Python 来源:网络整理
导读:我有一个看起来像这样的字典: d = {'Food': {'Fruit' : {'Apples' : {'Golden Del.' : ['Yellow'],'Granny Smith' : ['Green'],'Fuji' : ['Red'],},'Cherries' : ['Red'],'Bananas' : ['Yellow'],'Grapes' : {'Red Grapes' : ['Red'],'Green Grapes' : ['Gr

我有一个看起来像这样的字典:

d = {'Food': {'Fruit'  : {'Apples'    : {'Golden Del.'  : ['Yellow'],'Granny Smith' : ['Green'],'Fuji'         : ['Red'],},'Cherries'  : ['Red'],'Bananas'   : ['Yellow'],'Grapes'    : {'Red Grapes'   : ['Red'],'Green Grapes' : ['Green'],'Dessert': {'Baked Ds' : {'Cakes'         : {'Yellow Cake' : ['Yellow'],'Red Velvet'  : ['Red'],'Cookies'      : ['Yellow'],'Steak'  : ['Red'],'Other': ['Blue'],}

所以基本上是一个n嵌套的dict,其中每个值都是另一个dict或包含单个项的列表.

假设我想通过单个列表项过滤它,例如“Red”,结果将是:

d = {'Food': {'Fruit'  : {'Apples'    : {'Fuji'        : ['Red'],'Grapes'    : {'Red Grapes'  : ['Red'],'Dessert': {'Baked Ds' : {'Cakes'        : {'Red Velvet'  : ['Red'],}

因此结构保持不变,但是除了列表项之外没有“红色”的所有内容都被删除,一直到层次结构.

有什么建议?我已经搞砸了一段时间并想出了这个,但它似乎不起作用:

def filterNestedDict(node,searchItem):
    if isinstance(node,list):
        return node
    else:
        for key,value in node.iteritems():
            if isinstance(value,dict) and value is not {}:
                return {key: filterNestedDict(value,searchItem)}
            elif searchItem in value:
                return {key: filterNestedDict(value,searchItem)}

return filterNestedDict(bigTree,searchItem)

我怀疑这只是一个递归问题,但任何建议都会非常感激.

谢谢!

最佳答案
你非常接近,这应该为你做的伎俩:

def filter_nested_dict(node,search_term):
    if isinstance(node,list):
        if node[0] == search_term:
            return node
        else:
            return None
    else:
        dupe_node = {}
        for key,val in node.iteritems():
            cur_node = filter_nested_dict(val,search_term)
            if cur_node:
                dupe_node[key] = cur_node
        return dupe_node or None

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读