python之flatten操作

例如:

复制代码
li=[[1,2],[3,4],[5,6]]
print [j for i in li for j in i]
#or
from itertools import chain
print list(chain(*li))
#or
a=[[1,2],[3,4],[5,6]]
t=[]
[t.extend(i) for i in a]
print t
#or
print sum(li,[])
复制代码

对于复杂一些的,如:li=[1,[2],[[3]],[[4,[5],6]]],上面的方法就不好使了,得换个方法了,
从结构上看像是树状的,很容易联想到了目录的遍历,于是就有了下面的做法:

复制代码
def flat(tree):
    res = []
    for i in tree:
        if isinstance(i, (list, tuple)):
            res.extend(flat(i))
        else:
            res.append(i)
    return res
复制代码

另一种思路,嵌套列表无非就是有很多成对的方括号,一维的列表只有一对,把中间的去掉就行了,转换为字符串就好办了

def flatten(seq):
    s=str(seq).replace('[', '').replace(']', '') #当然也可以用正则
    return [eval(x) for x in s.split(',') if x.strip()]

不过,这种做法对于列表中出现包含"["或"]"的字符串时就无能为力了,需要改进.


其他方法:

国外某论坛上见到的,同样是递归,一行搞定

flat = lambda L: sum(map(flat,L),[]) if isinstance(L,list) else [L]

 

flatten = lambda x: [y for l in x for y in flatten(l)] if isinstance(x, (list, tuple)) else [x]


下面这个方法用到Tkinter模块,在邮件列表看到的方法。估计很多同学还不知道它能办到吧,也算是python自带。注意,windows版的python都自带Tkinter模块的,linux默认则没有

复制代码
from Tkinter import _flatten

li=reduce(lambda *x:list(x),range(2,6),[1])
print li
print _flatten(li)
#Out:
#[[[[[1], 2], 3], 4], 5]
#(1, 2, 3, 4, 5)
#对元组同样适用

 

posted @ 2015-11-18 08:35  l_g1990  阅读(1031)  评论(0编辑  收藏  举报