鱼C论坛

 找回密码
 立即注册
查看: 1001|回复: 2

[技术交流] Python 实现 flatten()

[复制链接]
发表于 2020-4-2 17:28:38 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 永恒的蓝色梦想 于 2020-4-11 15:30 编辑

Python 实现 flatten()


语法
  1. flatten(iterable, /)
复制代码


参数
参数描述
iterable可迭代对象


描述
flatten 函数可以用来压平可迭代对象。

返回值
这个函数会返回一个生成器。

实现方式
递归

原理
如果 iterable 中的一个元素实现了 __iter__ 方法,则递归取它的值。

例子
  1. >>> [1,[2,[3,[4,[5,[6,[7]]]]]]]
  2. [1, [2, [3, [4, [5, [6, [7]]]]]]]
  3. >>> list(flatten(_))
  4. [1, 2, 3, 4, 5, 6, 7]
复制代码
  1. >>> def gen1():
  2.         yield 1
  3.         yield 2
  4.         yield 3

  5. >>> def gen2():
  6.         yield 4
  7.         yield gen1()

  8. >>> def gen3():
  9.         yield 5
  10.         yield 6
  11.         yield gen2()

  12. >>> def gen4():
  13.         yield 7
  14.         yield gen3()

  15. >>> list(gen4())
  16. [7, <generator object gen3 at 0x000001EF0093B5F0>]
  17. >>> list(flatten(gen4()))
  18. [7, 5, 6, 4, 1, 2, 3]
复制代码


代码
  1. def flatten(it, /):
  2.     for i in it:
  3.         if hasattr(i,'__iter__'):
  4.             yield from flatten(i)
  5.         
  6.         else:
  7.             yield i
复制代码

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-4-2 17:30:52 | 显示全部楼层
二楼
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-27 07:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表