1.20 合并多个字典或映射

    假如你有如下两个字典:

    现在假设你必须在两个字典中执行查找操作(比如先从 中找,如果找不到再在 b 中找)。一个非常简单的解决方案就是使用 collections 模块中的 ChainMap 类。比如:

    1. from collections import ChainMap
    2. c = ChainMap(a,b)
    3. print(c['x']) # Outputs 1 (from a)
    4. print(c['y']) # Outputs 2 (from b)
    5. print(c['z']) # Outputs 3 (from a)

    一个 ChainMap 接受多个字典并将它们在逻辑上变为一个字典。然后,这些字典并不是真的合并在一起了, 类只是在内部创建了一个容纳这些字典的列表并重新定义了一些常见的字典操作来遍历这个列表。大部分字典操作都是可以正常使用的,比如:

    对于字典的更新或删除操作总是影响的是列表中第一个字典。比如:

    1. >>> c['z'] = 10
    2. >>> c['w'] = 40
    3. >>> del c['x']
    4. >>> a
    5. >>> del c['y']
    6. Traceback (most recent call last):
    7. ...
    8. KeyError: "Key not found in the first mapping: 'y'"
    9. >>>

    ChainMap 对于编程语言中的作用范围变量(比如 , locals 等)是非常有用的。事实上,有一些方法可以使它变得简单:

    作为 ChainMap 的替代,你可能会考虑使用 update() 方法将两个字典合并。比如:

    1. >>> a = {'x': 1, 'z': 3 }
    2. >>> b = {'y': 2, 'z': 4 }
    3. >>> merged = dict(b)
    4. >>> merged.update(a)
    5. >>> merged['x']
    6. 1
    7. >>> merged['y']
    8. >>> merged['z']
    9. 3
    10. >>>

    ChainMap 使用原来的字典,它自己不创建新的字典。所以它并不会产生上面所说的结果,比如:

    1. >>> a = {'x': 1, 'z': 3 }
    2. >>> b = {'y': 2, 'z': 4 }
    3. >>> merged = ChainMap(a, b)
    4. >>> merged['x']
    5. 1
    6. >>> a['x'] = 42
    7. >>> merged['x'] # Notice change to merged dicts
    8. 42
    9. >>>

    原文: