簡體   English   中英

遞歸測試dict是否包含在dict中

[英]Recursively test if dict is contained in dict

我需要知道在 Python 3 中是否遞歸地將一個字典包含在另一個字典中:

first  = {"one":"un", "two":"deux", "three":"trois" , "sub": { "s1": "sone" }}
second = {"one":"un", "two":"deux", "three":"trois", "foo":"bar", "sub": { "s1": "sone", "s2": "stwo"}}

如果 dict 中包含的 dict 中描述的字典視圖的使用是一種非常好的方法,但不處理遞歸情況。

我想出了這個功能:

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

哪個工作:

>>> first.items() <= second.items()
False
>>> isIn(first, second)
True

有沒有更好(更 Pythonic)的方式?

這是一個較短的版本,不需要try / except並處理參數類型不同的情況:

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM