Python使用子列表拆分列表

时间:2013-09-02 06:53:31

标签: python list itertools sublist

我的列表有问题。我有一个包含许多子列表的列表。这看起来像这样:

L=[[1,5],[1,1,2,8,5,6],[6,46,35,86,24,3,34,46,23,35],[12,14,53,24,41,53],[1,3,6,4,3,8],[2,5,54,4,61,72,65,54],[43,6,2,6,51,3,43,13,64,52,5,8,3,57,52]]

我想要的是这样的:

L1=[1,5]
L2=[1,1,2,8,5,6]
L3=[6,46,35,86,24,3,34,46,23,35]
L4=[12,14,53,24,41,53]
L5=[1,3,6,4,3,8]
...

我用itertools.groupby()尝试过,但这只是给了我:

L=[[[1,5],[1,1,2,8,5,6],[1,3,6,4,3,8]],[6,46,35,86,24,3,34,46,23,35],[12,14,53,24,41,53],[2,5,54,4,61,72,65,54],[43,6,2,6,51,3,43,13,64,52,5,8,3,57,52]]

我怎样才能做我想做的事?

4 个答案:

答案 0 :(得分:4)

您无需创建变量L1L2L3等。列表索引已经满足您的需求:

L=[[1,5],
   [1,1,2,8,5,6],
   [6,46,35,86,24,3,34,46,23,35],
   [12,14,53,24,41,53],
   [1,3,6,4,3,8],
   [2,5,54,4,61,72,65,54],
   [43,6,2,6,51,3,43,13,64,52,5,8,3,57,52]]

print L[0]  # prints [1, 5]
print L[4]  # prints [1, 3, 6, 4, 3, 8]

# If you want the first element of the first list in L, you use
L[0][0]

无论L的大小如何,这都具有工作优势。如果L很大,你不需要制作多个变量,或者为每个可能的L大小重写你的程序。

答案 1 :(得分:2)

我能为你做的最好 - 用L1,L2之类的键创建一个dict:

>>> {'L{}'.format(i): x for i, x in enumerate(L, 1)}
{'L1': [1, 5],
 'L2': [1, 1, 2, 8, 5, 6],
 'L3': [6, 46, 35, 86, 24, 3, 34, 46, 23, 35],
 'L4': [12, 14, 53, 24, 41, 53],
 'L5': [1, 3, 6, 4, 3, 8],
 'L6': [2, 5, 54, 4, 61, 72, 65, 54],
 'L7': [43, 6, 2, 6, 51, 3, 43, 13, 64, 52, 5, 8, 3, 57, 52]}

答案 2 :(得分:2)

首先,itertools.groupby()在这里不会帮助你。

你可以在这里使用解压缩,这是python中的一个很棒的功能(在我看来):

L1, L2, L3, L4, L5, L6, L7 = L

但是如果你想要这样的东西,那么你正在寻找错误的方法。考虑一下字典:

d = {}
for i, j in enumerate(L, 1):
    d['L{}'.format(i)] = j

打印d给出:

{'L6': [2, 5, 54, 4, 61, 72, 65, 54], 'L7': [43, 6, 2, 6, 51, 3, 43, 13, 64, 52, 5, 8, 3, 57, 52], 'L4': [12, 14, 53, 24, 41, 53], 'L5': [1, 3, 6, 4, 3, 8], 'L2': [1, 1, 2, 8, 5, 6], 'L3': [6, 46, 35, 86, 24, 3, 34, 46, 23, 35], 'L1': [1, 5]}

答案 3 :(得分:0)

你可以使用索引!!

 L1=L[0]
 L2=L[1]

依旧......

 print L1
 >> [1,5]