range(len(list)) or enumerate(list)?
Possible Duplicate:
Only index needed: enumerate or (x)range?
Which of these would be considered better/clearer/faster/more 'Pythonic'? I don't care about the content of the list L
, just how long it is.
a = [f(n) for n, _ in enumerate(L)]
or
a = [f(n) for n in range(len(L))]
If it makes any difference, the function f
makes use of len(list)
as well.
Some quick timing runs seem to give the 2nd option using range()
a slight edge over 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
and just for fun using xrange()
(Python v2.7.2)
timeit a = [f(n) for n in xrange(len(mlist))]
10000 loops, best of 3: 99 us per loop
I would favor readable code first, then using xrange()
if available (ie, Pre-Python v 3.x), followed by range()
and enumerate()
.
The (x)range solution is faster, because it has less overhead, so I'd use that.
In Python 2.x, use xrange
instead of range
, because xrange
uses less memory, because it doesn't create a temporary list. In Python 3.x, there is only range
, which is the less-memory version.
Assuming you're using Python 2.x, if you use len()
, you should use xrange()
as it will avoid creating a list of the numbers in the range.
And in this case, I'd go with len()
because you are using the indices, not the items in the list.
上一篇: 你如何将一个列表分成均匀大小的块?