假设,
dict1 = { "A" : ["a","b","c"]} # old one
dict2 = { "A" : ["a","b","c","d"]} # new one
#i wanna get
dict3 = {"A":["d"]}
据我所知,采用“deepdiif”是不对的,因为它必须具有与字典相同的架构 我怎样才能以简单易行的方式获得字典添加数据的差异?
您可以使用
set.symmetric_difference()
来做到这一点:
set(*dict1.values()).symmetric_difference(*dict2.values())
如果您的字典键不止一个(但两者具有相同的键集):
>>> dict1
{'A': ['a', 'b', 'c'], 'B': [1, 2, 3, 4]}
>>> dict2
{'A': ['a', 'b', 'c', 'd'], 'B': [4, 3, 2]}
>>> {k: list(set(dict1[k]).symmetric_difference(dict2[k])) for k in dict1}
{'A': ['d'], 'B': [1]}
编辑:如果您不知道先验两个字典具有相同的键集,您可以通过将其视为“差异联合”来使其更加健壮,其中键位于两个键的交集中集合是不同的,不在交集的键被视为正常的
dict.union
:
def differentiated_union(d1, d2):
result = {}
for key in set(d1).union(d2):
d1_vals = d1.get(key, set())
d2_vals = d2.get(key, set())
result[key] = list(set(d1_vals).symmetric_difference(d2_vals))
return result
输出:
>>> differentiated_union(dict1, dict2)
{'A': ['d'], 'B': [1], 'C': ['z', 'x', 'y'], 'D': ['p', 'q', 'r']}