def combine_dicts(a, b): if b is None: return a return dict(a.items() + b.items() + [(k, combine_dicts(a[k], b[k])) for k in set(b) & set(a)])
a和b这里应该都是dict型数据,这个函数怎么理解呢,尤其是最后一个return那里??
这是 Python 2 的写法。来个 Python 3.6 版:
def dict_deep_merge(a, b): if not b: return a return {**a, **b, **{k: dict_deep_merge(a[k], b[k]) for k in set(a) & set(b)}}
应该高效一点。别的差不多。
并不算什么神级代码,也不是很难理解。递归合并相同 key 的值而已。你需要知道的知识点:
dict 的 items 方法
tuple 的相加
集合的交
dict 参数的意义
雷雷
提问一下,代码是有一定的问题吧,如果相同的key里,value值是字符串的话,items这个函数会报错吧?
这是 Python 2 的写法。来个 Python 3.6 版:
应该高效一点。别的差不多。
并不算什么神级代码,也不是很难理解。递归合并相同 key 的值而已。你需要知道的知识点:
dict 的 items 方法
tuple 的相加
集合的交
dict 参数的意义
雷雷
提问一下,代码是有一定的问题吧,如果相同的key里,value值是字符串的话,items这个函数会报错吧?