当前位置: 首页 > news >正文

使用yield压平嵌套字典有多简单?

我们经常遇到各种字典套字典的数据,例如:

nest_dict = {'a': 1,'b': {'c': 2,'d': 3,'e': {'f': 4}},'g': {'h': 5},'i': 6,'j': {'k': {'l': {'m': 8}}}
}

有没有什么简单的办法,把它压扁,变成:

{'a': 1,'b_c': 2,'b_d': 3,'b_e_f': 4,'g_h': 5,'i': 6,'j_k_l_m': 8
}

你肯定想到了使用递归来解决这个问题,那么你可以试一试,看看你的递归函数有多少行代码。

今天,我们使用yield关键字来实现这个需求,在不炫技的情况下,只需要8行代码。在炫技的情况下,只需要3行代码。

要快速地把这个嵌套字典压扁,我们需要从下网上来处理字段。例如对于b->e->f->4这条路径,我们首先把最里面的{'f': 4}转换为一个元组('f', 4)。然后,把这个元组向上抛出,于是得到了元组('e', ('f', 4))。我们把 e拼接到f的前面,变为:('e_f', 4),继续往上抛出,得到('b', ('e_f', 4))。再把b拼接到e_f上面,得到('b_e_f', 4)。完成一条线路的组装。

这个逻辑如果使用yield关键字来实现,就是:

def flat(x):for key, value in x.items():if isinstance(value, dict):for k, v in flat(value):k = f'{key}_{k}'yield (k, v)else:yield (key, value)

运行结果如下图

通过使用 yield关键字,字典的key会像是在流水线上一样,一层一层从内向外进行组装,从而形成完整的路径。

http://www.lryc.cn/news/468320.html

相关文章:

  • express中使用morgan打印请求数据日志文件,按日期分割
  • 干货 | 2024 AI+智慧城市安全解决方案白皮书(免费下载)
  • 超越 React Query:探索更高效的数据请求策略
  • Scala trait
  • AI大法之C语言哈希表算法比较两个文件去重
  • Scala 提取器(Extractor)
  • 【主机漏洞扫描常见修复方案】:Tomcat安全(机房对外Web服务扫描)
  • MySQL数据库之——事务(Transaction)详解
  • LabVIEW提高开发效率技巧----事件日志记录
  • 整合XXL-Job任务调度平台
  • hi3536上ffmpeg带rtmp移植
  • 在PHP中,读取大文件
  • N-gram详解
  • 电路中的电源轨及地的区别和处理
  • k8s可以部署私有云吗?私有云部署全攻略
  • 编辑器资源管理器
  • 高性能数据分析利器DuckDB在Python中的使用
  • IAR全面支持旗芯微车规级MCU,打造智能安全的未来汽车
  • **深入浅出:TOGAF中的应用架构**
  • Pytorch学习--DataLoader的使用
  • 代购系统界的“数据大厨”:定制API数据处理,烹饪出美味佳肴
  • 二十、Innodb底层原理与Mysql日志机制深入剖析
  • 数据库设计与管理的要点详解
  • 国家科技创新2030重大项目
  • 如何使用 Flutter Local Notifications 插件
  • 【openEuler/Centos】yum安装软件报Error: GPG check FAILED【分析根因弄明白,亲测有效不浪费时间】
  • 实现vuex源码,手写
  • 使用 Python 和 Pandas 处理 Excel 数据:合并单元格示例
  • Python poetry 虚拟环境
  • 面试官:你会如何设计QQ中的网络协议?