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 und b sollten beide Daten vom Typ Diktat sein, insbesondere die letzte Rückgabe. ?
这是 Python 2 的写法。来个 Python 3.6 版:
应该高效一点。别的差不多。
并不算什么神级代码,也不是很难理解。递归合并相同 key 的值而已。你需要知道的知识点:
dict 的 items 方法
tuple 的相加
集合的交
dict 参数的意义
提问一下,代码是有一定的问题吧,如果相同的key里,value值是字符串的话,items这个函数会报错吧?