求大神解读一段神级的Python代码,谢谢!!

查看:80
本文介绍了求大神解读一段神级的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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆