首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python list遍历remove(

有这样一个列表: s=list('abcdefg')  现在因为某种原因我们需要从s中踢出一些不需要的元素,方便起见这里直接以踢出所有元素的循环代替: for e in s: s.remove(...e)  结果却是: In [3]: s Out[3]: ['b', 'd', 'f'] 多次示例后发现,这种remove方式保持着隔1删1的规律。...15]: for e in s: ...: print("第"+str(i)+"次循环删前:s=",s) ...: print(e) ...: s.remove...可以看到第1次循环时e的赋值跳过‘b’直接变成了‘c’,鉴于不太清楚底层内存分配和计数的原理,只能做以下推测: 第0次循环后s的因为remove了‘a’导致长度减小了1,第1次循环时依然按s[1]给e赋值...,在Python中应避免在遍历序列时直接删除序列的元素,这里有一个替代的办法,我们可以遍历s的一个copy: # s[0:]替换成s.copy()也可以 for e in s[0:]: s.remove

1.9K10
您找到你想要的搜索结果了吗?
是的
没有找到

python list.remove的坑

python中使用list的时候,通常需要用到移除其中某些元素,而remove函数就正好可以移除元素,所以就会想到循环遍历list,利用remove函数移除元素,例如下面一段代码: >>> cl=[15...flu.remove(i) ... 1005 1008 1011 1015 3008 3013 3015 10 14 2008 2013 1007 1012 3007 3012 7 9 13 2009...1014, 3001, 3002, 3004, 3009, 6, 8, 11, 2001, 2002, 2004, 2007, 2011, 2014, 4001] 上面的一段代码期望实现的是删除list...那是因为list的遍历是基于下标的,当你删除其中的一个元素的时候,列表实际上已经发生了变化,该元素后面的所有元素都往前移动了一个位置,所以下次遍历的时候就会跳过该元素后面的一个元素。...>>> list(set(flu).difference(set(cl))) [4001, 4901, 6, 1001, 1002, 1003, 1004, 2001, 2002, 2003, 2004

91810
领券