for循环
a = [i for i in range(10)]
首先构建一个列表 0-9
for i in a:
print(i)
循环打印
删除列表元素
a.remove(i)
删除a列表当中的元素i
bug复现
这些都是没有问题的 但是当我有一个需求 遍历列表 当i等于某些特定值的时候 从列表a中删除元素i
比如 判断7 和8是否在列表当中 如果存在 的话 删除列表当中的7和8 我编写的代码如下:
a = [i for i in range(10)]
for i in a:
print(i)
if i in [7,8]:
a.remove(i)
print(a)
看着没有问题吧 但是当我看见输出的时候 我直接宏机了
在 print(i)时 8 并没有输出出来 输出7之后 直接输出了9 并且在最后的结果当中8也没有被删除掉
原因分析–我被下标背刺了
在for循环当中 python根据下标读取数据
在上面的例子当中数字和下标对应的 但是当我删除掉7这个数据后 列表的长度变了 7之后的元素下标也变了 本来7的下标为7 但是当删除掉7这个元素之后8的下标变成了7 python 已经读取过了下标为7的数据(当时数值为7)所以在下次循环的时候会读取下标为8的数据 就变成了9 所以数据8就被神奇的跳过了 这也是为什么最终结果当中8还存在列表当中
a = [i for i in range(10)]
for i in a:
print('数值:{},当前元素下标:{},当前列表长度:{}'.format(i, a.index(i), len(a)))
if i in [7, 8]:
a.remove(i)
print(a)
这样看就明了很多了 当数值为7时 下标为7,长度为10 之后删除了7 紧接着就访问了下标为8的元素 此时下标为8的元素为9 列表长度为9 ,此时8这个数据就被跳过了。
解决方案
a = [i for i in range(10)]
print(a)
remove_list = []
for i in a:
print('数值:{},当前元素下标:{},当前列表长度:{}'.format(i, a.index(i), len(a)))
if i in [7, 8]:
remove_list.append(i)
if remove_list:
for num in remove_list:
a.remove(num)
print('删除{}'.format(num))
print(a)
新增一个列表记录需要删除掉的数据 循环完之后直接删除