python - 合并字典的字典和总和值

标签 python python-3.x dictionary merge

我正在寻找一种方法将多个字典相互合并,其中也包含嵌套字典。嵌套字典的数量不是静态的而是动态的。

最后,Final dict 应该包含所有dict 的dict 和它们的值的总和:

COUNTRY1 = {'a': {'X': 10, 'Y': 18, 'Z': 17}, 'b': {'AA':{'AAx':45,'AAy':22},'BB':{'BBx':45,'BBy':22}}, 'c': 100}
COUNTRY2 = {'a': {'U': 12, 'V': 34, 'W': 23}, 'b': {'AA':{'AAz':23,'AAa':26},'BB':{'BBz':11,'BBa':15}}, 'c': 115}
COUNTRY3 = {'a': {'Y': 15, 'Z': 14, 'X': 12}, 'b': {'AA':{'AAx':45,'AAz':22},'BB':{'BBy':45,'BBz':22}}, 'c': 232}

# After merging the dictionaries the result should look like:
ALL
>>> {'a': {'X': 22, 'Y': 33, 'Z': 31, 'U': 12, 'V': 34, 'W': 23}, 'b': {'AA':{'AAx':90,'AAy':22,'AAz':45,'AAa':26},'BB':{'BBx':45,'BBy':67, 'BBz':33,'BBa':15}}, 'c': 447}

我尝试了以下代码,它允许嵌套字典最多 3 个嵌套字典。不幸的是,代码没有达到我的预期。因此它看起来不是很干净,我觉得这可以用递归函数来完成,但是我找不到一种方法来做到这一点。

COUNTRIES = ['COUNTRY1','COUNTRY2', 'COUNTRY3']
ALL = {}
for COUNTRY_CODE in COUNTRIES:

    COUNTRY = pickle.load(open(COUNTRY_CODE+".p", "rb"))
    keys = COUNTRY.keys()
    for key in keys:
        try:
            keys2 = COUNTRY[key].keys()
            print(key, keys2)

            for key2 in keys2:
                try:
                    keys3 = COUNTRY[key][key2].keys()
                    print(key2, keys3)

                    for key3 in keys3:
                        try:
                            keys4 = COUNTRY[key][key2][key3].keys()
                            print(key3, keys4)
                        except:
                            print(key3, "NO KEY3")
                            if not key3 in ALL[key][key2]:
                                ALL[key][key2][key3] = COUNTRY[key][key2][key3]
                            else:
                                ALL[key][key2][key3] =+ COUNTRY[key][key2][key3]

                except:
                    print(key2, "NO KEY2")
                    if not key2 in ALL[key]:
                        ALL[key][key2] = COUNTRY[key][key2]
                    else:
                        ALL[key][key2] =+ COUNTRY[key][key2]

        except:
            print(key, "NO KEY")
            if not key in ALL:
                ALL[key] = COUNTRY[key]
            else:
                ALL[key] =+ COUNTRY[key]

print(ALL)

最佳答案

问题是您需要根据值的类型来确定如何处理字典键。基本思想是:

  • 输入是一对字典,输出是和字典
  • 单步执行两个输入字典
  • 如果一个值是一个字典,递归
  • 如果一个值是一个数字,把它加到另一个数字上

这很容易通过理解来实现:

def add_dicts(d1, d2):
    def sum(v1, v2):
        if v2 is None:
            return v1
        try:
            return v1 + v2
        except TypeError:
            return add_dicts(v1, v2)
    result = d2.copy()
    result.update({k: sum(v, d2.get(k)) for k, v in d1.items()})
    return result

副本确保 d2 中不在 d1 中的任何键都被简单地复制过来。

您现在可以总结如下:

ALL = add_dicts(add_dicts(COUNTRY1, COUNTRY2), COUNTRY3)

更一般地说,您可以使用 functools.reduce对无限数量的词典执行此操作:

dicts = [COUNTRY1, COUNTRY2, COUNTRY3]
ALL = reduce(add_dicts, dicts)

关于python - 合并字典的字典和总和值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51860378/

相关文章:

python - 如何从 .csv 文件中拆分数据集以进行训练和测试?

python - Selenium 从 CookieJar 添加 Cookie

python - 添加包含每个用户评分数的列,pandas

python - 如何使用请求模块跳过连接超时 url

Django模板: custom template tag to display dictionary of dictionary

python - 4 个嵌套循环的时间复杂度是多少,每个循环都取决于父循环

python - 嵌入式平台OpenCV的特征检测

Python的int函数性能

dictionary - 可靠的线程安全映射

javascript - 使用 JavaScript map reduce 从数组中删除项目