我需要知道在Python 3中,dict是否递归地包含在另一个dict中:
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中描述的字典视图是一种非常好的方法,但不处理递归情况
我想出了这个函数:
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
有更好的(更像Python的)方法吗
下面是一个略短的版本,它不需要
try
/except
,并处理参数类型不同的情况:相关问题 更多 >
编程相关推荐