鱼C论坛

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

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

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

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

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

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

Python 实现 flatten()


语法
flatten(iterable, /)

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


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

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

实现方式
递归

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

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

>>> def gen2():
        yield 4
        yield gen1()

>>> def gen3():
        yield 5
        yield 6
        yield gen2()

>>> def gen4():
        yield 7
        yield gen3()

>>> list(gen4())
[7, <generator object gen3 at 0x000001EF0093B5F0>]
>>> list(flatten(gen4()))
[7, 5, 6, 4, 1, 2, 3]

代码
def flatten(it, /):
    for i in it:
        if hasattr(i,'__iter__'):
            yield from flatten(i)
        
        else:
            yield i

本帖被以下淘专辑推荐:

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

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-23 08:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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