L = [1, 2, 3, 2, 2, 1, 5]
i = 0
while i < len(L):
if L[i] == 2:
L.pop(i)
continue
i += 1
print(L)
Python列表的删除方法:
1)list.pop(index): 根据索引删除列表中的一个元素(默认最后一个),并返回该元素的值
2)list.remove(obj) : 移出列表中某个值的第一个匹配项
3)list.clear(): 清空列表
4)del(list[index]) : 根据索引删除
先前写这道题的时候用了一个for循环,发现行不通,大概是这样:
for i in range(0, len(L)):
if L[i] == 2:
L.pop(i)
i = i - 1
print("删除后:",L)
为什么pop()后 i 要 -1 ?
这是因为删除了元素后,原列表L发生了变化,下标为1的元素删了之后,原来下标为2的元素现在就变成了下标为1的元素,如果不-1,那么将有一个元素被跳过
这个代码报了错,原因是:

索引超出了范围
通过输出 i 的值发现:
for i in range(0, 7):
print("i=", i)
for i in range(0, 7):
print("i=", i)
i += 2
这两种写法输出的结果是一样的

也就是后面的修改并没有影响到 for 中的 i 值
本文介绍了Python删除列表元素的几种方式,包括pop()、remove()、clear()和del语句。针对一个问题,即使用for循环删除列表中的2时遇到的索引错误,文章解释了为何在删除元素后需要更新索引,并给出了导致‘索引超出范围’错误的原因。最后,文章通过对比两种不同写法的效果,强调了循环中删除元素时正确处理索引的重要性。
2171

被折叠的 条评论
为什么被折叠?



