python实现嵌套功能_PYTHON压平嵌套列表的简单实现

list 是 Python 中使用最频繁的数据类型, 标准库里面有丰富的函数可以使用。

不过,如果把多维列表转换成一维列表(不知道这种需求多不多),还真不容易找到好用的函数,

要知道Ruby、Mathematica、Groovy中可是有flatten的啊。

如果列表是维度少的、规则的,还算好办

例如:

1

2

3

4

5

6

7

8

9

10

11

12

li=[[1,2],[3,4],[5,6]]

print [jfor iin lifor jin i]

#or

from itertoolsimport chain

print list(chain(*li))

#or

a=[[1,2],[3,4],[5,6]]

t=[]

[t.extend(i)for iin a]

print t

#or

print sum(li,[])

对于复杂一些的,如:li=[1,[2],[[3]],[[4,[5],6]]],上面的方法就不好使了,得换个方法了,

从结构上看像是树状的,很容易联想到了目录的遍历,于是就有了下面的做法:

1

2

3

4

5

6

7

8

def flat(tree):

res= []

for iin tree:

if isinstance(i,list):

res.extend(flat(i))

else:

res.append(i)

return res

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

1

2

3

def flatten(seq):

s=str(seq).replace('[', '').replace(']', '')#当然也可以用正则

return [eval(x)for xin s.split(',')if x.strip()]

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

其他方法:

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

1

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

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

1

2

3

4

5

6

7

8

9

from Tkinterimport _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)

#对元组同样适用

还有一些第三方模块提供这样的功能,如sympy、numpy、pipe等

对于嵌套的元组,无需多说了吧,只需稍加改动就可以了

以上这篇PYTHON压平嵌套列表的简单实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值