博客
关于我
python 用for循环删除list列表中的元素,删除不干净的问题
阅读量:301 次
发布时间:2019-03-03

本文共 840 字,大约阅读时间需要 2 分钟。

在处理列表时,使用remove方法删除元素可能会导致循环出错,因为删除会改变列表结构,影响索引。使用切片list1[:]确保循环不受影响。


今天遇到了一个有趣的Python问题,需要从一个列表中删除特定类型的元素。具体来说,列表里的元素是文件名,分为.txt和.jpg两种类型,目标是删除所有.txt文件,只保留.jpg文件。

为了实现这个目标,我写了如下的代码:

list1 = ['a.txt','b.txt','c.txt','a.jpg','b.jpg','c.jpg']for im in list1:    if im.split('.')[-1] != 'jpg':        list1.remove(im)print(list1)

运行后,输出结果是['b.txt', 'a.jpg', 'b.jpg', 'c.jpg']。这显然不对,因为预期只剩下.jpg文件,而b.txt却没有被删除。

经过进一步研究,我发现问题出在循环过程中使用remove方法删除元素上。当删除一个元素时,后面的元素索引会自动调整,这会导致循环中某些元素被跳过或重复处理,从而出现意外的结果。

为了修正这个问题,我在循环中使用了list1[:], 这样在循环处理时,列表的元素不会随着删除而改变。修改后的代码如下:

list1 = ['a.txt','b.txt','c.txt','a.jpg','b.jpg','c.jpg']for im in list1[:]:    if im.split('.')[-1] != 'jpg':        list1.remove(im)print(list1)

运行后,结果变为['a.jpg', 'b.jpg', 'c.jpg'],这正是预期的结果。

总结一下,使用remove方法删除列表中的元素时,循环过程中不要修改列表的长度和结构,否则可能导致循环出错。使用切片list1[:]可以创建一个静态的列表,这样循环就不会受影响了。

转载地址:http://zvgl.baihongyu.com/

你可能感兴趣的文章
NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>
NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
查看>>
NIH发布包含10600张CT图像数据库 为AI算法测试铺路
查看>>
Nim教程【十二】
查看>>
Nim游戏
查看>>
NIO ByteBuffer实现原理
查看>>
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>
nio 中channel和buffer的基本使用
查看>>
NIO三大组件基础知识
查看>>
NIO与零拷贝和AIO
查看>>
NIO同步网络编程
查看>>
NIO基于UDP协议的网络编程
查看>>
NIO笔记---上
查看>>
NIO蔚来 面试——IP地址你了解多少?
查看>>