没有内置函数或方法可以执行此操作。但是,您可以轻松定义自己的。
def common_entries(*dcts): if not dcts: return for i in set(dcts[0]).intersection(*dcts[1:]): yield (i,) + tuple(d[i] for d in dcts)
这是基于您提供的“手动方法”建立的,但是与一样
zip,可以用于任意数量的词典。
>>> da = {'a': 1, 'b': 2, 'c': 3}>>> db = {'a': 4, 'b': 5, 'c': 6}>>> list(common_entries(da, db))[('c', 3, 6), ('b', 2, 5), ('a', 1, 4)]当仅提供一个字典作为参数时,它实际上返回
dct.items()。
>>> list(common_entries(da))[('c', 3), ('b', 2), ('a', 1)]没有字典,它将返回一个空的生成器(就像
zip())
>>> list(common_entries())[]



