初学Python,遇到过这样的问题,在遍历list的时候,删除符合条件的数据,可是总是报异常,代码如下:
num_list = [1, 2, 3, 4, 5]print(num_list)for i in range(len(num_list)): if num_list[i] == 2: num_list.pop(i) else: print(num_list[i])print(num_list)会报异常:IndexError: list index out of range
原因是在删除list中的元素后,list的实际长度变小了,但是循环次数没有减少,依然按照原来list的长度进行遍历,所以会造成索引溢出。
于是我修改了代码如下:
num_list = [1, 2, 3, 4, 5]print(num_list)for i in range(len(num_list)): if i >= len(num_list): break if num_list[i] == 2: num_list.pop(i) else: print(num_list[i])print(num_list)这回不会报异常了,但是打印结果如下:
[1, 2, 3, 4, 5]145[1, 3, 4, 5][Finished in 0.441s]虽然最后,list中的元素[2]确实被删除掉了,但是,在循环中的打印结果不对,少打印了[3]。
思考了下,知道了原因,当符合条件,删除元素[2]之后,后面的元素全部往前移,于是[3, 4, 5]向前移动,那么元素[3]的索引,就变成了之前[2]的索引(现在[3]的下标索引变为1了),后面的元素以此类推。可是,下一次for循环的时候,是从下标索引2开始的,于是,取出了元素[4],就把[3]漏掉了。
把代码修改成如下,结果一样,丝毫没有改观:
num_list = [1, 2, 3, 4, 5]print(num_list)for item in num_list: if item == 2: num_list.remove(item) else: print(item)print(num_list)既然知道了问题的根本原因所在,想要找到正确的方法,也并不难,于是我写了如下的代码:
num_list = [1, 2, 3, 4, 5]print(num_list)i = 0while i