2014-06-06 64 views
-1

我有一个列表如下;根据元素的位置从列表创建新的列表

['US', 20, 'en', 'UK', 21, 'en', 'Fra', 23, 'fr'] 

哪个是最有效的方式来创建3上面这样的新列表?

['US', 'UK', 'Fra'] 
[20, 21, 23] 
['en', 'en', 'fr'] 
+2

我没有downvote,但问题很可能downvoted因为它是一个虚拟复制 - 也就是说,它不会需要大量的搜索提供答案,而不是问这个问题的。 – aestrivex

+1

Downvotes通常是缺乏研究的结果。你有没有尝试过自己,并确定它对你的需求来说太慢了? – chepner

+0

我知道的唯一方法是运行循环并获取新列表。我猜它是一个facepalm问题。但仍然... – richie

回答

1

在单(有趣)线:

>>> l = ['US', 20, 'en', 'UK', 21, 'en', 'Fra', 23, 'fr'] 
>>> lists = [[l[3*i+j] for i in range(0, int(len(l)/3))] for j in range(0, 3)] 
>>> lists 
[['US', 'UK', 'Fra'], [20, 21, 23], ['en', 'en', 'fr']] 

你一定要采取lists[0]lists[1]lists[2]

+2

内部列表'[l [i + j]我在范围内(0,len(l),3)]'更清晰 – njzk2

+0

是的!我没有意识到范围函数的第三个参数。 – julienc

1

您可以使用numpy

import numpy as np 
DATA = ['US', 20, 'en', 'UK', 21, 'en', 'Fra', 23, 'fr'] 
x= np.array(DATA).reshape(3,len(DATA)/3).T.tolist() 

print x[0] 
print x[1] 
print x[2] 

它打印

['US', 'UK', 'Fra'] 
['20', '21', '23'] 
['en', 'en', 'fr'] 
0

这不是最有效的方式,但你可以用切片与步参数,实现使它非常易于理解:

>>> l = ['US', 20, 'en', 'UK', 21, 'en', 'Fra', 23, 'fr'] 
>>> l[::3] 
['US', 'UK', 'Fra'] 
>>> l[1::3] 
[20, 21, 23] 
>>> l[2::3] 
['en', 'en', 'fr'] 
+0

或者实际创建请求的列表,[[l [:: 3],l [1 :: 3],l [2 :: 3]]' – aestrivex

+0

@aestrivex这个问题只提到了创建三个列表,而不是列表名单。 –

+0

对不起,你是对的我不知何故误解了它 – aestrivex

2

切片和清单理解应该做的伎俩。它可能不是最有效的,但它简洁易读。

data = ['US', 20, 'en', 'UK', 21, 'en', 'Fra', 23, 'fr'] 
result = [ data[i::3] for i in range(3) ] 
相关问题