求大神解读一段神级的Python代码,谢谢!!
问题描述
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那里??
问题解答
回答1:这是 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 参数的意义
回答2:函数的作用合并两个dict比如a = {’a’: {’A’: 1}, ’b’: 1}b = {’a’: {’B’: 1}}合并成{’a’: {’A’: 1, ’B’: 1}, ’b’: 1}set(b) & set(a)是取a,c的key交集,如上a,b的key交集为a, 再递归运行子dict回答3:
提问一下,代码是有一定的问题吧,如果相同的key里,value值是字符串的话,items这个函数会报错吧?