我有一个列表如下;根据元素的位置从列表创建新的列表
['US', 20, 'en', 'UK', 21, 'en', 'Fra', 23, 'fr']
哪个是最有效的方式来创建3上面这样的新列表?
['US', 'UK', 'Fra']
[20, 21, 23]
['en', 'en', 'fr']
我有一个列表如下;根据元素的位置从列表创建新的列表
['US', 20, 'en', 'UK', 21, 'en', 'Fra', 23, 'fr']
哪个是最有效的方式来创建3上面这样的新列表?
['US', 'UK', 'Fra']
[20, 21, 23]
['en', 'en', 'fr']
在单(有趣)线:
>>> 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]
。
您可以使用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']
这不是最有效的方式,但你可以用切片与步参数,实现使它非常易于理解:
>>> 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']
切片和清单理解应该做的伎俩。它可能不是最有效的,但它简洁易读。
data = ['US', 20, 'en', 'UK', 21, 'en', 'Fra', 23, 'fr']
result = [ data[i::3] for i in range(3) ]
我没有downvote,但问题很可能downvoted因为它是一个虚拟复制 - 也就是说,它不会需要大量的搜索提供答案,而不是问这个问题的。 – aestrivex
Downvotes通常是缺乏研究的结果。你有没有尝试过自己,并确定它对你的需求来说太慢了? – chepner
我知道的唯一方法是运行循环并获取新列表。我猜它是一个facepalm问题。但仍然... – richie