原文链接
参考链接
可以看出1并未被完全删除完
具体分析一下这段代码:
第一次循环,循环索引为0,此时索引为0的元素是1,满足条件,因此mylist中的第一个1被删除,此时mylist变为[1,2,1,1,3,4];
第二次循环,循环索引为1,此时新列表中,索引为1的元素是2,不满足条件,mylist仍然为[1,2,1,1,3,4];
第三次循环,循环索引为2,此时列表中,索引为2的元素是1,满足条件,remove方法会再次删除一个1,但是remove会删除第一次出现的1(即删除索引为0的那个1),因此列表变为[2,1,1,3,4];
第四次循环,循环索引为3,新列表中,索引为3的元素是3,不满足条件,mylist仍然为[2,1,1,3,4];
第五次循环,循环索引为4,此时列表中,索引为4的元素是4,不满足条件,mylist仍然为[2,1,1,3,4];
此时,由于新列表长度为5,于是循环结束。
注意:remove的用法:不能按照索引循环 因为删除元素索引会发生变化
s = "4193 with words"
s = list(s)
l = len(s)
# for i in range(len(s)): 不能按照索引循环
# if s[i] == ' ':
# s.remove(s[i])
for i in s:
if i == ' ':
s.remove(i)
print(s)