在'for'循环中访问索引?

Joan Venge 3312 python loops list

如何访问索引本身以获取如下列表?

ints = [8, 23, 45, 12, 78]
for i in ints:
    print('item #{} = {}'.format(???, i))

当我使用循环遍历它时for,如何访问循环索引,在这种情况下从1到5?

Mike Hordeck.. 5655

使用其他状态变量(例如索引变量(通常在C或PHP等语言中使用))被认为是非pythonic.

更好的选择是使用enumerate()Python 2和3中提供的内置函数:

for idx, val in enumerate(ints):
    print(idx, val)

查看PEP 279了解更多信息.

  • 正如Aaron在下面指出的那样,如果你想获得1-5而不是0-4,则使用start = 1. (48认同)

Aaron Hall.. 714

使用for循环,如何访问循环索引,在这种情况下从1到5?

用于enumerate在迭代时使用元素获取索引:

for index, item in enumerate(items):
    print(index, item)

请注意,Python的索引从零开始,因此您可以使用上面的0到4.如果您想要计数,1到5,请执行以下操作:

for count, item in enumerate(items, start=1):
    print(count, item)

Unidiomatic控制流程

您要求的是Pythonic等效于以下内容,这是大多数低级语言程序员使用的算法:

index = 0            # Python's indexing starts at zero
for item in items:   # Python's for loops are a "for each" loop 
    print(index, item)
    index += 1

或者在没有for-each循环的语言中:

index = 0
while index < len(items):
    print(index, items[index])
    index += 1

或者有时在Python中更常见(但是通常是单一的):

for index in range(len(items)):
    print(index, items[index])

使用枚举函数

Python的enumerate函数通过隐藏索引的会计,并将迭代封装到另一个迭代(一个enumerate对象)中来减少视觉混乱,该迭代产生索引的两项元组和原始迭代将提供的项.看起来像这样:

for index, item in enumerate(items, start=0):   # default is zero
    print(index, item)

这段代码示例相当于Python的惯用代码和非代码的代码之间差异的规范示例.惯用代码是复杂的(但并不复杂)Python,以其打算使用的方式编写.惯用语代码是该语言的设计者所期望的,这意味着通常这段代码不仅更具可读性,而且更高效.

算一算

即使您不需要索引,但是您需要计算迭代次数(有时候是可取的),您可以从这里开始,1最终的数字将是您的计数.

for count, item in enumerate(items, start=1):   # default is zero
    print(item)

print('there were {0} items printed'.format(count))

当你说你希望从1到5时,计数似乎更像你打算要求的(而不是索引).


打破它 - 一步一步的解释

为了打破这些例子,假设我们有一个我们想要用索引迭代的项目列表:

items = ['a', 'b', 'c', 'd', 'e']

现在我们传递这个iterable来枚举,创建一个枚举对象:

enumerate_object = enumerate(items) # the enumerate object

我们可以从这个迭代中拉出第一个项目,我们将在循环中获得该next函数:

iteration = next(enumerate_object) # first iteration from enumerate
print(iteration)

我们看到我们得到了一个元组0,第一个索引,'a'第一个项目:

(0, 'a')

我们可以使用所谓的" 序列解包 "来从这个二元组中提取元素:

index, item = iteration
#   0,  'a' = (0, 'a') # essentially this.

当我们检查时index,我们发现它引用第一个索引0,并item引用第一个项目,'a'.

>>> print(index)
0
>>> print(item)
a

结论

  • Python索引从零开始
  • 要在迭代迭代时从迭代中获取这些索引,请使用枚举函数
  • 以惯用的方式使用枚举(以及元组解包)创建更易读和可维护的代码:

这样做:

for index, item in enumerate(items, start=0):   # Python indexes start at zero
    print(index, item)


A.J... 135

这是很简单的,从开始它1以外0:

for index, item in enumerate(iterable, start=1):
   print index, item

注意

重要的暗示,虽然有点误导,因为这index将是一个tuple (idx, item).很高兴去.

  • 问题是关于列表索引; 因为它们从0开始,所以从其他数字开始没有什么意义,因为索引是错误的(是的,OP在问题中也说错了).否则,正如你所指出的那样,调用`index,item`只是`index`元组的变量是非常误导的.只需使用`for index,item in enumerate(ints)`. (10认同)

David Hanak.. 88

for i in range(len(ints)):
   print i, ints[i]

  • 请改用枚举 (36认同)
  • 对于3.0之前的版本应该是`xrange`. (10认同)
  • 对于上面的Python 2.3,使用枚举内置函数,因为它更像Pythonic. (2认同)

Charitoo.. 45

正如Python中的标准一样,有几种方法可以做到这一点.在所有例子中假设:lst = [1, 2, 3, 4, 5]

1.使用枚举(被认为是最惯用的)

for index, element in enumerate(lst):
    # do the things that need doing here

在我看来,这也是最安全的选择,因为已经消除了进入无限递归的可能性.项目及其索引都保存在变量中,无需编写任何其他代码来访问该项目.

2.创建一个变量来保存索引(使用for)

for index in range(len(lst)):   # or xrange
    # you will have to write extra code to get the element

3.创建一个变量来保存索引(使用while)

index = 0
while index < len(lst):
    # you will have to write extra code to get the element
    index += 1  # escape infinite recursion

总有另一种方式

如前所述,还有其他方法可以做到这一点,这里没有解释,甚至可能在其他情况下应用更多.例如使用itertools.chainwith for.它比其他示例更好地处理嵌套循环.


Charlie Mart.. 26

老式的方式:

for ix in range(len(ints)):
    print ints[ix]

列表理解:

[ (ix, ints[ix]) for ix in range(len(ints))]

>>> ints
[1, 2, 3, 4, 5]
>>> for ix in range(len(ints)): print ints[ix]
... 
1
2
3
4
5
>>> [ (ix, ints[ix]) for ix in range(len(ints))]
[(0, 1), (1, 2), (2, 3), (3, 4), (4, 5)]
>>> lc = [ (ix, ints[ix]) for ix in range(len(ints))]
>>> for tup in lc:
...     print tup
... 
(0, 1)
(1, 2)
(2, 3)
(3, 4)
(4, 5)
>>> 


Andriy Ivane.. 19

Python 2.7中访问循环中列表索引的最快方法是使用范围方法用于小型列表,并枚举方法用于中型和大型列表.

请参阅不同的方法可用于遍历列表和访问索引值和它们的性能指标(我想是对您有用)下面的代码样本:

from timeit import timeit

# Using range
def range_loop(iterable):
    for i in range(len(iterable)):
        1 + iterable[i]

# Using xrange
def xrange_loop(iterable):
    for i in xrange(len(iterable)):
        1 + iterable[i]

# Using enumerate
def enumerate_loop(iterable):
    for i, val in enumerate(iterable):
        1 + val

# Manual indexing
def manual_indexing_loop(iterable):
    index = 0
    for item in iterable:
        1 + item
        index += 1

请参阅以下每种方法的效果指标:

from timeit import timeit

def measure(l, number=10000):
print "Measure speed for list with %d items" % len(l)
print "xrange: ", timeit(lambda :xrange_loop(l), number=number)
print "range: ", timeit(lambda :range_loop(l), number=number)
print "enumerate: ", timeit(lambda :enumerate_loop(l), number=number)
print "manual_indexing: ", timeit(lambda :manual_indexing_loop(l), number=number)

measure(range(1000))
# Measure speed for list with 1000 items
# xrange:  0.758321046829
# range:  0.701184988022
# enumerate:  0.724966049194
# manual_indexing:  0.894635915756

measure(range(10000))
# Measure speed for list with 100000 items
# xrange:  81.4756360054
# range:  75.0172479153
# enumerate:  74.687623024
# manual_indexing:  91.6308541298

measure(range(10000000), number=100)
# Measure speed for list with 10000000 items
# xrange:  82.267786026
# range:  84.0493988991
# enumerate:  78.0344707966
# manual_indexing:  95.0491430759

结果,使用range方法是列出最快的1000个项目.对于大小> 10 000项的列表enumerate是赢家.

添加以下一些有用的链接:

  • "可读性计数"小<1000范围内的速度差异无关紧要.在已经很小的时间指标上慢了3%. (4认同)

ytpillai.. 13

首先,索引将从0到4.编程语言从0开始计数; 不要忘记,否则你会遇到索引超出范围的异常.for循环中所需要的只是一个从0到4的变量,如下所示:

for x in range(0, 5):

请记住,我写了0到5,因为循环在最大值之前停止了一个数字.:)

获取索引使用的值

list[index]


小智.. 11

根据这个讨论:http://bytes.com/topic/python/answers/464012-objects-list-index

循环计数器迭代

循环索引的当前习惯使用内置的"范围"函数:

for i in range(len(sequence)):
    # work with index i

循环使用元素和索引可以通过旧的习语或使用新的"zip"内置函数[2]来实现:

for i in range(len(sequence)):
    e = sequence[i]
    # work with index i and element e

要么

for i, e in zip(range(len(sequence)), sequence):
    # work with index i and element e

通过http://www.python.org/dev/peps/pep-0212/

  • 这不适用于迭代生成器.只需使用enumerate(). (22认同)

Liam.. 10

您可以使用以下代码执行此操作:

ints = [8, 23, 45, 12, 78]
index = 0

for value in (ints):
    index +=1
    print index, value

如果需要在循环结束时重置索引值,请使用此代码:

ints = [8, 23, 45, 12, 78]
index = 0

for value in (ints):
    index +=1
    print index, value
    if index >= len(ints)-1:
        index = 0


Anurag Misra.. 8

这个问题的最佳解决方案是使用枚举内置的python函数.
枚举返回元组
第一个值是索引
第二个值是该索引处的数组元素

In [1]: ints = [8, 23, 45, 12, 78]

In [2]: for idx, val in enumerate(ints):
   ...:         print(idx, val)
   ...:     
(0, 8)
(1, 23)
(2, 45)
(3, 12)
(4, 78)


小智.. 6

如果我要迭代,nums = [1, 2, 3, 4, 5]我会做

for i, num in enumerate(nums, start=1):
    print(i, num)

或获得长度为 l = len(nums)

for i in range(1, l + 1):
    print(i, nums[i])


ARGeo.. 6

这是for循环访问索引时得到的结果:

for i in enumerate(items): print(i)

for i, val in enumerate(items): print(i, val)

for i, val in enumerate(items): print(i)

希望这可以帮助。


DrM.. 5

在您的问题中,您写道:“在这种情况下,我如何从1到5访问循环索引?”

但是,列表的索引从零开始。因此,那么我们需要知道您真正想要的是列表中每个项目的索引和项目,还是您真正想要的是从1开始的数字。幸运的是,在Python中,轻松执行这两个操作或两者都很容易。

首先,要澄清一下,该enumerate函数迭代地返回列表中每个项目的索引和相应项目。

alist = [1, 2, 3, 4, 5]

for n, a in enumerate(alist):
    print("%d %d" % (n, a))

上面的输出是

alist = [1, 2, 3, 4, 5]

for n, a in enumerate(alist):
    print("%d %d" % (n, a))

请注意,索引从0开始运行。这种索引在包括Python和C在内的现代编程语言中很常见。

如果希望循环跨越列表的一部分,则可以将标准Python语法用于列表的一部分。例如,要从列表中的第二个项目循环到最后一个但不包括最后一个项目,可以使用

for n, a in enumerate(alist[1:-1]):
    print("%d %d" % (n, a))

请再次注意,输出索引从0开始,

0 1
1 2
2 3
3 4
4 5

这给我们带来了start=n的开关enumerate()。这只是使索引偏移,您可以等效地在循环内向索引简单地添加一个数字。

for n, a in enumerate(alist, start=1):
    print("%d %d" % (n, a))

其输出是

for n, a in enumerate(alist[1:-1]):
    print("%d %d" % (n, a))


归档时间:

查看次数:

1939847 次

最近记录:

1 年,1 月 前