Python循环列表删除元素问题

有人会遇到这种问题,遍历列表,想删除列表中的某几个元素,执行后发现有些并没有删除到,

比如以下代码

a=[1,2,3,4,5,6]print(a)
for i in a:
    if i==3 or i==4:
        a.remove(i)print(a)

从代码看主要就是想删除a列表中的 3 4 元素,

程序的结果是:

[1, 2, 3, 4, 5]

[1, 2, 4, 5]

结果不尽人意,原因是我们在遍历的时候

  • seek走到了3元素的位置
  • if判断remove 3  这个元素
  • 3这个位置删除后位置空出来了,后面的元素就往前移动,替代了3的位置
  • seek继续走到下一个,本来是4元素的,但是4元素往前移了,就错过了,seek走到了5元素的位置

避免这个这个问题的就需要避免for循环,当然上面的例子可以有很多方法去删除,但是当我们遇到一个不能避免for循环的情况,可以将要删除的元素存储到另外一个列表里面,最后一并删除.

a=[1,2,3,4,5]
d=[]
print(a)
for i in a:
    if i==3 or i==4:
        d.append(i)
for i in d:
    a.remove(i)
print(a)

#[1, 2, 3, 4, 5]
#[1, 2, 5]
时间: 2024-12-09 05:16:57

Python循环列表删除元素问题的相关文章

python 原生列表删除元素方法总结

一.列表方法remove(),按值删除,删除首个符合的元素 二.列表方法pop(),按索引删除,默认删除最后一个元素 三.del函数,删除某个变量或者某些元素 原文地址:https://www.cnblogs.com/dearL/p/9545402.html

python列表删除元素整理

先看一个例子: test1 = ['a','b','c','','']for i in test1: if i == '': test1.remove(i) #删除空元素 print(test1) >>>['a', 'b', 'c', ''] 这时发现并没有达到我们想要的结果,原因分析如下: 要了解一下python列表的数据结构,列表属于连续线性表,它的连续在于有一块连续的内存储存着列表中元素的地址,如图(忽略地址与值所占的字节,只为方便举例子): 当然也可以通过一个代码来看证明一下:

python中列表删除和多重循环退出

在学习python的时候,会有一些梗非常不适应,在此列举列表删除和多重循环退出的例子: 列表删除里面的坑 比如我们有一个列表里面有很多相同的值,假如:nums=[1,6,6,3,6,2,10,2,100],我想去掉6,可以这样写: nums=[1,6,6,3,6,2,10,2,100] for n in nums: if n==6: nums.remove(n) nums.sort() print(nums)#输出结果:[1, 2, 2, 3, 6, 10, 100] 排序显示后列表中还有一个6

javascript在数组的循环中删除元素

在开发JavaScript应用的过程中,经常会遇到在循环中移除指定元素的需求. 按照常规的思路,就是对数组进行一个for循环,然后在循环里面进行if判断,在判断中删除掉指定元素即可. 但是实际情况往往不会像预想的那样顺利运行. 出现的问题场景还原 (function () { var arr = [1, 2, 2, 3, 4, 5]; for (var i = 0; i < arr.length; i++){ // 打印数组中的情况,便于跟踪数组中数据的变化 console.log(i + '

Python - 字典(dict)删除元素

字典(dict)删除元素, 可以选择两种方式, dict.pop(key)和del dict[key]. 代码 # -*- coding: utf-8 -*- def remove_key(d, key): r = dict(d) del r[key] return r x = {1: 2, 3: 4, 4: 3, 2: 1, 0: 0} x.pop(1) print x x = {1: 2, 3: 4, 4: 3, 2: 1, 0: 0} del x[1] print x x = {1: 2,

Python遍历列表删除多个元素或者重复元素

比较容易的是用内置的set l1 = ['b','c','d','b','c','a','a'] l2 = list(set(l1)) print l2 还有一种据说速度更快的,没测试过两者的速度差别 l1 = ['b','c','d','b','c','a','a'] l2 = {}.fromkeys(l1).keys() print l2 这两种都有个缺点,祛除重复元素后排序变了: ['a', 'c', 'b', 'd'] 如果想要保持他们原来的排序: 用list类的sort方法 l1 =

Python统计列表中元素出现的次数

Python列表可以进行简单的统计,比如list的函数count()可以直接统计元素出现的次数. mylist = [2,2,2,2,2,2,3,3,3,3] myset = set(mylist) #删除列表中的重复元素   print myset    set([2, 3]) for item in myset: print mylist.count(item), " of ", item, " in list" 打印结果: 6 of 2 in list  #

Python从list删除元素

Paul同学刚来几天又要转走了,那么我们怎么把Paul 从现有的list中删除呢? 如果Paul同学排在最后一个,我们可以用list的pop()方法删除: >>> L = ['Adam', 'Lisa', 'Bart', 'Paul'] >>> L.pop() 'Paul' >>> print L ['Adam', 'Lisa', 'Bart'] pop()方法总是删掉list的最后一个元素,并且它还返回这个元素,所以我们执行 L.pop() 后,会打

Python遍历字典删除元素

这种方式是一定有问题的: d = {'a':1, 'b':2, 'c':3} for key in d: d.pop(key) 会报这个错误:RuntimeError: dictionary changed size during iteration 这种方式Python2可行,Python3还是报上面这个错误. d = {'a':1, 'b':2, 'c':3} for key in d.keys(): d.pop(key) Python3报错的原因是keys()函数返回的是dict_keys