python-分解多列表嵌套

针对多列表嵌套,如何获取所有元素?

之前使用for循环+if判断,进行分解,如下:

    for first_layer in lists:
        if isinstance(first_layer,list):
            for second_layer in first_layer:

                if isinstance(second_layer,list):

                    for third_layer in second_layer:

                        print third_layer

        else:
            print first_layer

但是,若遇到列表有4重嵌套、5重嵌套...等等,代码显得无比复杂、臃肿。


于是想到函数复用性,如下:

#!/usr/bin/env python
#coding:utf-8
fruit=[‘a‘,‘b‘,123,[‘c‘,345,‘d‘,[‘e‘,‘f‘,90],22,‘cc‘],‘po‘,34]
def layer(lists):
    for first_layer in lists:
        if isinstance(first_layer,list):
            layer(first_layer)
        else:
            print first_layer
layer(fruit)

这样,不管多少个列表嵌套,只需传参给函数就行,可以实现逐级分解。函数还能被移植调用,可用性增强。

本文出自 “蜗牛的家” 博客,请务必保留此出处http://winters.blog.51cto.com/5617866/1619684

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。