我使用的是Python 2.5,我想要一个这样的枚举(从1开始而不是0):

[(1, 2000), (2, 2001), (3, 2002), (4, 2003), (5, 2004)]

我知道在Python 2.6中你可以这样做:h = enumerate(range(2000, 2005), 1)来给出上面的结果,但在python2.5中你不能…

使用Python 2.5:

>>> h = enumerate(range(2000, 2005))
>>> [x for x in h]
[(0, 2000), (1, 2001), (2, 2002), (3, 2003), (4, 2004)]

有没有人知道在Python 2.5中如何获得想要的结果?


当前回答

Python 3

Python官方文档:enumerate(可迭代,start=0)

您不需要像这里的其他答案所建议的那样编写自己的生成器。内置的Python标准库已经包含了一个函数,它可以做你想要的事情:

>>> seasons = ['Spring', 'Summer', 'Fall', 'Winter']
>>> list(enumerate(seasons))
[(0, 'Spring'), (1, 'Summer'), (2, 'Fall'), (3, 'Winter')]
>>> list(enumerate(seasons, start=1))
[(1, 'Spring'), (2, 'Summer'), (3, 'Fall'), (4, 'Winter')]

内置函数等价于:

def enumerate(sequence, start=0):
  n = start
  for elem in sequence:
    yield n, elem
    n += 1

其他回答

>>> h = enumerate(range(2000, 2005))
>>> [(tup[0]+1, tup[1]) for tup in h]
[(1, 2000), (2, 2001), (3, 2002), (4, 2003), (5, 2004)]

由于这有点啰嗦,我建议编写自己的函数来泛化它:

def enumerate_at(xs, start):
    return ((tup[0]+start, tup[1]) for tup in enumerate(xs))

很简单,只要定义你自己想要的函数:

def enum(seq, start=0):
    for i, x in enumerate(seq):
        yield i+start, x

我不知道这些帖子怎么可能比下面的更复杂:

# Just pass the start argument to enumerate ...
for i,word in enumerate(allWords, 1):
    word2idx[word]=i
    idx2word[i]=word

在Python 2.5中最简单的方法是:

import itertools as it

... it.izip(it.count(1), xrange(2000, 2005)) ...

如果您需要一个列表,就像您看起来的那样,使用zip来代替它。

(顺便说一句,作为一般规则,从生成器或任何其他可迭代对象X中创建列表的最佳方法不是[X for X in X],而是list(X))。

from itertools import count, izip

def enumerate(L, n=0):
    return izip( count(n), L)

# if 2.5 has no count
def count(n=0):
    while True:
        yield n
        n+=1

现在h = list(enumerate(xrange(2000, 2005), 1))工作了。