使用 yield 压平嵌套字典有多简单?
我们经常遇到各种字典套字典的数据,例如:
1 | nest_dict = { |
有没有什么简单的办法,把它压扁
,变成:
1 | { |
你肯定想到了使用递归来解决这个问题,那么你可以试一试,看看你的递归函数有多少行代码。
今天,我们使用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
关键字来实现,就是:
1 | def flat(x): |
运行结果如下图所示:
通过使用 yield
关键字,字典的key
会像是在流水线上一样,一层一层从内向外进行组装,从而形成完整的路径。
在下一篇文章中,我们继续使用yield
关键字来解决字典与列表混合嵌套的情况。