范围(len(list))或枚举(list)?
可能重复:
只需要索引:枚举或(x)范围?
哪一个会被认为是更好/更清晰/更快/更'Pythonic'? 我不关心列表L
的内容,只是它有多长。
a = [f(n) for n, _ in enumerate(L)]
要么
a = [f(n) for n in range(len(L))]
如果它有什么区别,函数f
也使用len(list)
。
一些快速计时运行似乎给第二个选项使用range()
稍微优于enumerate()
:
timeit a = [f(n) for n, _ in enumerate(mlist)]
10000 loops, best of 3: 118 us per loop
timeit a = [f(n) for n in range(len(mlist))]
10000 loops, best of 3: 102 us per loop
只是为了使用xrange()
(Python v2.7.2)
timeit a = [f(n) for n in xrange(len(mlist))]
10000 loops, best of 3: 99 us per loop
我会首先支持可读代码,然后使用xrange()
如果可用)(即Pre-Python v 3.x),然后使用range()
和enumerate()
。
(x)范围解决方案速度更快,因为它具有更少的开销,所以我会使用它。
在Python 2.x中,使用xrange
而不是range
,因为xrange
使用较少的内存,因为它不会创建临时列表。 在Python 3.x中,只有range
,这是内存不足的版本。
假设你使用的是Python 2.x,如果你使用len()
,你应该使用xrange()
因为它会避免创建范围内的数字列表。
在这种情况下,我会使用len()
因为您使用的是索引,而不是列表中的项目。
上一篇: range(len(list)) or enumerate(list)?
下一篇: What is faster for loop using enumerate or for loop using xrange in Python?