我发现这段代码非常有趣.
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].