时间:2021-05-22
代码如下
dat=['1', '2', '3', '0', '0', '0']for item in dat: if item == '0': dat.remove(item)print(dat)#按要求是把'0'都删掉的,输出结果是['1', '2', '3', '0'] ??首先,remove(x) 移除的是序列首次碰到的元素x
理解:
遍历列表,item每一次都会变化,可以想象有一个指针指向后一个元素,指针是递增的,从头元素到尾元素直至遍历完。
容易想到指针 0 --> 1 --> 2 --> 3
到第四个元素(dat[3]), dat[3]=='0',dat.remove(item), dat=['1','2','3','0','0'] #列表现在有五个元素
继续:
指针指向第五个元素(dat[4]),dat[4]=='0',dat.remove(item), dat=['1','2','3','0'] #列表现在有四个元素
继续:
指针指向(查找)下一个元素(第六个),哎? 此时dat列表只剩下四个元素,找不到第六个,自然就结束循环了!
得出:
列表的增删操作最好不要在for循环里做,迭代内容随着循环而改变了,这样既不安全也没必要,
换句话说,就是在循环的时候,不要让循环体的(指针/索引)啥的发生变化。
解决:
可以通过复制一个新的表来做删除操作
dat=['1', '2', '3', '0', '0', '0']d = dat.copy()for item in dat: if item == '0': d.remove(item)print(d)以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
list.remove最近做项目的过程中,需要用到list.remove()方法,结果发现两个有趣的坑,经过分析后找到原因,记录一下跟大家分享一下。代码直接上一
remove()方法从列表中删除第一个obj。语法以下是remove()方法的语法:list.remove(obj)参数obj--这是可以从列表中移除该对象返回
java中的LIST在删除时,一般会用list.remove(o);但这样往往会出现问题,先来看下面的这段代码:packagecom.demo;importja
list.remove方法在删除元素的时候往往会出现漏删或者索引越界的情况示例如下:漏删:lst=[9,25,12,36]foriinlst:ifi>10:ls
Python关于删除list中的某个元素,一般有两种方法,pop()和remove()。remove()函数用于移除列表中某个值的第一个匹配项。remove()