我的列表有问题。我有一个包含许多子列表的列表。这看起来像这样:
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]]
我怎样才能做我想做的事?
答案 0 :(得分:4)
您无需创建变量L1
,L2
,L3
等。列表索引已经满足您的需求:
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]