求大神解读一段神级的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那里??

阅读 2.9k
3 个回答

这是 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 参数的意义

函数的作用合并两个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

提问一下,代码是有一定的问题吧,如果相同的key里,value值是字符串的话,items这个函数会报错吧?

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题