地图(sum,zip(* list))是任意长度列表的列的最快方法吗?

时间:2012-07-19 14:35:24

标签: python performance list optimization

我想知道是否有人可以建议一种方法来对比地图更快的列表求和(sum,zip(* list))。

示例:

import timeit

print timeit.Timer('''
[ (a[x]+b[x]+c[x]) for x in xrange(len(a)) ]
''', '''
a = range(200)
b = range(199,-1,-1)
c = range(1,201)
''').timeit(number = 1000)

print timeit.Timer('''
map(sum,zip(*d))
''', '''
a = range(200)
b = range(199,-1,-1)
c = range(1,201)
d = [a,b,c]''').timeit(number = 1000)

print timeit.Timer('''
[sum(x) for x in zip(*d)]
''', '''
a = range(200)
b = range(199,-1,-1)
c = range(1,201)
d = [a,b,c]''').timeit(number = 1000)

结果:

0.0317891459248 #list comprehension
0.0406545608382 #sum with zip
0.0532605665307 #map sum with zip

注意:我知道我在挑剔,但我很好奇是否有人有更好的建议。

1 个答案:

答案 0 :(得分:7)

这个怎么样?

print timeit.Timer('''
d.sum(axis=0)
''', '''
import numpy as np
a = range(200)
b = range(199,-1,-1)
c = range(1,201)
d = np.array([a,b,c])''').timeit(number = 1000)

当然,这假设您的列表包含某种数字类型......