繁体   English   中英

枚举是迭代列表中的字符串字母而不是元素

[英]enumerate is iterating of letters of strings in a list instead of elements

我正在尝试使用enumerate来迭代列表并存储列表的元素以及使用索引来获取另一个相同大小的列表的索引。

使用一个愚蠢的例子:

animal = ['cat', 'dog', 'fish' , 'monkey']
name = ['george', 'steve', 'john', 'james']

x = []
for count, i in enumerate(animal):
    y = zip(name[count], i)
    x = x +y

而不是生成两个列表的每个元素的元组。 它按字母生成元组。 有没有办法做到这一点,但获取每个列表的元素而不是每个字母? 我知道可能有更好的 Pythonic 方式来完成同样的任务,但我特别希望这样做。

enumerate()没有做这样的事情。 你在这里配对字母:

y = zip(name[count], i)

例如,对于animal的第一个元素, count0并且i设置为'cat' name[0]'george' ,所以你要求 Python zip() 'george''cat'

>>> zip('george', 'cat')
[('g', 'c'), ('e', 'a'), ('o', 't')]

这以较短的字长为上限。

如果你想要一个元组,只需使用:

y = (name[count], i)

然后附加到您的x列表中:

x.append(y)

可以使用zip()而不是enumerate()来创建配对:

x = zip(name, animal)

无需任何循环:

>>> animal = ['cat', 'dog', 'fish' , 'monkey']
>>> name = ['george', 'steve', 'john', 'james']
>>> zip(name, animal)
[('george', 'cat'), ('steve', 'dog'), ('john', 'fish'), ('james', 'monkey')]

当您使用zip()它实际上会在每个索引处创建相应元素的元组列表。

因此,当您提供strings作为输入时,它会以每个字符的元组列表的形式提供结果。 例子 -

>>> zip('cat','george')
[('c', 'g'), ('a', 'e'), ('t', 'o')]

当您遍历列表中的每个元素并使用 zip 时,这就是您正在做的事情。

相反,您应该直接使用zip ,而不是遍历列表的元素。

例子 -

>>> animal = ['cat', 'dog', 'fish' , 'monkey']
>>> name = ['george', 'steve', 'john', 'james']
>>> zip(animal,name)
[('cat', 'george'), ('dog', 'steve'), ('fish', 'john'), ('monkey', 'james')]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM