首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >递归测试dict中是否包含dict

递归测试dict中是否包含dict
EN

Stack Overflow用户
提问于 2016-05-03 13:22:48
回答 1查看 92关注 0票数 1

我需要知道在Python 3中,dict是否被递归地包含在另一个dict中:

代码语言:javascript
复制
first  = {"one":"un", "two":"deux", "three":"trois" , "sub": { "s1": "sone" }}
second = {"one":"un", "two":"deux", "three":"trois", "foo":"bar", "sub": { "s1": "sone", "s2": "stwo"}}

使用Test if dict contained in dict中描述的字典视图是一种非常好的方法,但不处理递归情况。

我想出了这个功能:

代码语言:javascript
复制
def isIn(inside, outside):
    for k, v in inside.items():
        try:
            if isinstance(v,dict):
                if not isIn(v, outside[k]):
                    return False
            else:
                if v != outside[k]:
                    return False
        except KeyError:
            return False

    return True

其中的工作:

代码语言:javascript
复制
>>> first.items() <= second.items()
False
>>> isIn(first, second)
True

有没有更好的(更多的毕达通)方法?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-05-03 13:44:44

这里有一个更短的版本,它不需要try/except,可以处理参数类型不同的情况:

代码语言:javascript
复制
def isIn(inside, outside):
    if isinstance(inside, dict) and isinstance(outside, dict):
        return all(isIn(v, outside.get(k, object())) for k, v in inside.items())
    return inside == outside

print(isIn(first, second)) # True
print(isIn(second, first)) # False
print(isIn({}, 9999)) # False
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37005406

复制
相关文章

相似问题

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