求大神解读一段神级的Python代码,谢谢!!
本文介绍了求大神解读一段神级的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那里??
解决方案
这是 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 参数的意义
这篇关于求大神解读一段神级的Python代码,谢谢!!的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文