Python在列表理解中使用枚举

Posted

技术标签:

【中文标题】Python在列表理解中使用枚举【英文标题】:Python using enumerate inside list comprehension 【发布时间】:2012-06-02 09:14:50 【问题描述】:

假设我有一个这样的列表:

mylist = ["a","b","c","d"]

要获得与索引一起打印的值,我可以像这样使用 Python 的 enumerate 函数

>>> for i,j in enumerate(mylist):
...     print i,j
...
0 a
1 b
2 c
3 d
>>>

现在,当我尝试在 list comprehension 中使用它时,它给了我这个错误

>>> [i,j for i,j in enumerate(mylist)]
  File "<stdin>", line 1
    [i,j for i,j in enumerate(mylist)]
           ^
SyntaxError: invalid syntax

所以,我的问题是:在列表理解中使用 enumerate 的正确方法是什么?

【问题讨论】:

【参考方案1】:

试试这个:

[(i, j) for i, j in enumerate(mylist)]

您需要将i,j 放在一个元组中,列表解析才能工作。或者,鉴于enumerate()已经返回了一个元组,你可以直接返回它而无需先解包:

[pair for pair in enumerate(mylist)]

无论哪种方式,返回的结果都符合预期:

> [(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]

【讨论】:

不是必须是元组。任何使用 i 和 j 返回值的表达式都可以 枚举的使用很棒,使用itertools如何提高效率 请记住,元组是由, 而不是 () 构建的。所以“将i,j 放在一个元组中”是没有意义的,因为i,j 已经是一个元组了!问题是列表比较解析器需要语句组的括号。【参考方案2】:

明确一点,这与 enumerate 无关,与列表解析语法有关。

这个列表推导返回一个元组列表:

[(i,j) for i in range(3) for j in 'abc']

这是一个字典列表:

[i:j for i in range(3) for j in 'abc']

列表列表:

[[i,j] for i in range(3) for j in 'abc']

语法错误:

[i,j for i in range(3) for j in 'abc']

这是不一致的(恕我直言)并且与字典理解语法混淆:

>>> i:j for i,j in enumerate('abcdef')
0: 'a', 1: 'b', 2: 'c', 3: 'd', 4: 'e', 5: 'f'

还有一组元组:

>>> (i,j) for i,j in enumerate('abcdef')
set([(0, 'a'), (4, 'e'), (1, 'b'), (2, 'c'), (5, 'f'), (3, 'd')])

正如 Óscar López 所说,您可以直接传递枚举元组:

>>> [t for t in enumerate('abcdef') ] 
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd'), (4, 'e'), (5, 'f')]

【讨论】:

【参考方案3】:

或者,如果您不坚持使用列表推导:

>>> mylist = ["a","b","c","d"]
>>> list(enumerate(mylist))
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]

【讨论】:

【参考方案4】:

这是一种方法:

>>> mylist = ['a', 'b', 'c', 'd']
>>> [item for item in enumerate(mylist)]
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]

或者,您可以这样做:

>>> [(i, j) for i, j in enumerate(mylist)]
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]

您收到错误的原因是您缺少 ij 周围的 () 以使其成为元组。

【讨论】:

【参考方案5】:

如果您使用的是长列表,则列表理解似乎更快,更不用说更具可读性了。

~$ python -mtimeit -s"mylist = ['a','b','c','d']" "list(enumerate(mylist))"
1000000 loops, best of 3: 1.61 usec per loop
~$ python -mtimeit -s"mylist = ['a','b','c','d']" "[(i, j) for i, j in enumerate(mylist)]"
1000000 loops, best of 3: 0.978 usec per loop
~$ python -mtimeit -s"mylist = ['a','b','c','d']" "[t for t in enumerate(mylist)]"
1000000 loops, best of 3: 0.767 usec per loop

【讨论】:

+1 我没有测试它,但我敢打赌[t for t in enumerate(my list)] 会更快。【参考方案6】:

要明确说明元组。

[(i, j) for (i, j) in enumerate(mylist)]

【讨论】:

【参考方案7】:

所有答案都很棒的家伙。我知道这里的问题是针对枚举的,但是像这样的事情怎么样,只是另一个角度

from itertools import izip, count
a = ["5", "6", "1", "2"]
tupleList = list( izip( count(), a ) )
print(tupleList)

如果必须在性能方面并行迭代多个列表,它会变得更加强大。只是一个想法

a = ["5", "6", "1", "2"]
b = ["a", "b", "c", "d"]
tupleList = list( izip( count(), a, b ) )
print(tupleList)

【讨论】:

以上是关于Python在列表理解中使用枚举的主要内容,如果未能解决你的问题,请参考以下文章

python3,使用枚举保持索引的嵌套列表中的最小值

python之枚举--内置函数-enumerate()

使用列表理解 Python 创建新列

python 枚举列表中的项目

Python itertools groupby 在列表理解中的多次使用

python 使用列表理解从两个列表中的字典