python:使用列表切片作为for循环的目标

我发现这段代码非常有趣.

a = [0, 1, 2, 3]

for a[-1] in a:
    print(a)

输出如下:

[0, 1, 2, 0]
[0, 1, 2, 1]
[0, 1, 2, 2]
[0, 1, 2, 2]

我试图理解为什么python会这样做.是因为python试图重用索引吗? for循环以某种方式切片列表?

我们可以在迭代列表时添加或删除元素,但是当我们尝试使用索引访问变量时,它会产生奇怪的输出.

有人可以帮我理解列表中for循环和索引之间的交互吗?或者只是解释这个输出?

解决方法:

它按预期工作. (对于“预期”的一些解释,至少.)

将代码重写为此代码,以防止在任何时候误解[-1]:

a = [a for a in range(0,4)]
for b in a:
    print (b)
    a[-1] = b
    print (a)

告诉我们

0
[0, 1, 2, 0]
1
[0, 1, 2, 1]
2
[0, 1, 2, 2]
2
[0, 1, 2, 2]

这清楚地说明了对[-1]的b赋值是立即完成的,在迭代时改变了列表.

四个循环执行以下操作:

> a [-1]设置为列表的第一个值,0.结果现在为[0,1,2,0].
> a [-1]设置为第二个值,1.结果(很明显)[0,1,2,1].
> a [-1]设置为2,因此结果为[0,1,2,2] – 再次,只有[-1]被更改.
>最后,将[-1]设置为a中的最后一个值,因此它实际上不会改变,最终结果为[0,1,2,2].

上一篇:使用带有OR条件的MySQL JOIN中的索引


下一篇:Python:根据索引范围将列表拆分为子列表