少说话多写代码之Python学习053——类的成员(生成器的使用:递归)

栏目: Python · 发布时间: 6年前

内容简介:前面我们get到了一个技能,生成器。那么如果我们想依次输出一个数组,但是数组中又嵌套数组,又嵌套数组...嵌套未知层,那么如何实现?如果使用for可能就有点不方便了,这时我们需要递归。我们可以这样做,

前面我们get到了一个技能,生成器。

那么如果我们想依次输出一个数组,但是数组中又嵌套数组,又嵌套数组...嵌套未知层,那么如何实现?如果使用for可能就有点不方便了,这时我们需要递归。

我们可以这样做,

def myFlatten(seq):
    try:
        for list in seq:
            for item in myFlatten(list):
                yield  item
    except Exception:
        yield  seq

测试我们的代码

seque=[[1,[2,[3]]],[4,[5,[6,[7,[8]]]]],[9,10],[11]]

for item in myFlatten(seque):
    print(item)

输出

print(list(myFlatten(seque)))

输出

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]

对于上述实现方式,我们发现并不完善,如果数组是字符串那就可能引发typeError异常。于是我们增加一个检查的逻辑。

def myFlattenAdvance(seq):
    try:
        try: seq+''
        except TypeError:
            pass
        else:raise  TypeError
        for list in seq:
            for item in myFlattenAdvance(list):
                yield  item
    except Exception:
        yield  seq

发现类型错误,则在异常中处理,本段代码中,我们不做异常处理。

测试调用如下,

strSeq=['魔礼青',['魔礼海',['魔礼红','魔礼寿']]]
for item in myFlattenAdvance(strSeq):
    print(item)

输出

魔礼青
魔礼海
魔礼红
魔礼寿
print(list(myFlattenAdvance(strSeq)))

输出

['魔礼青', '魔礼海', '魔礼红', '魔礼寿']

这样我们可以递归字符串类型的数组了。

工程文件下载: https://download.csdn.net/download/yysyangyangyangshan/10821963


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据结构及应用算法教程

数据结构及应用算法教程

2011-5 / 45.00元

《数据结构及应用算法教程(修订版)》从数据类型的角度,分别讨论了四大类型的数据结构的逻辑特性、存储表示及其应用。此外,还专辟一章,以若干实例阐述以抽象数据类型为中心的程序设计方法。书中每一章后都配有适量的习题,以供读者复习提高之用。第1~9章还专门设有“解题指导与示例”一节内容,不仅给出答案,对大部分题目提供了详尽的解答注释;其中的一些算法题还给出了多种解法。书中主要算法和最后一章的实例中的全部程......一起来看看 《数据结构及应用算法教程》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换