我需要合并多个字典,下面是我所拥有的示例:
dict1 = {1:{"a":{A}}, 2:{"b":{B}}}
dict2 = {2:{"c":{C}}, 3:{"d":{D}}A B C和D是树的叶子,就像{"info1":"value", "info2":"value2"}一样
有一个未知级别(深度)的字典,它可能是{2:{"c":{"z":{"y":{C}}}}}
在我的例子中,它表示一个目录/文件结构,节点是docs,叶子是文件。
我想合并它们以获得:
dict3 = {1:{"a":{A}}, 2:{"b":{B},"c":{C}}, 3:{"d":{D}}}我不确定如何使用Python轻松做到这一点。
发布于 2014-07-19 14:27:54
这个简单的递归过程将一个字典合并到另一个字典中,同时覆盖冲突的键:
#!/usr/bin/env python2.7
def merge_dicts(dict1, dict2):
""" Recursively merges dict2 into dict1 """
if not isinstance(dict1, dict) or not isinstance(dict2, dict):
return dict2
for k in dict2:
if k in dict1:
dict1[k] = merge_dicts(dict1[k], dict2[k])
else:
dict1[k] = dict2[k]
return dict1
print (merge_dicts({1:{"a":"A"}, 2:{"b":"B"}}, {2:{"c":"C"}, 3:{"d":"D"}}))
print (merge_dicts({1:{"a":"A"}, 2:{"b":"B"}}, {1:{"a":"A"}, 2:{"b":"C"}}))输出:
{1: {'a': 'A'}, 2: {'c': 'C', 'b': 'B'}, 3: {'d': 'D'}}
{1: {'a': 'A'}, 2: {'b': 'C'}}https://stackoverflow.com/questions/7204805
复制相似问题