博客
关于我
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/

你可能感兴趣的文章
orm总结
查看>>
paddle的两阶段基础算法基础
查看>>
SpringBoot中重写addCorsMapping解决跨域以及提示list them explicitly or consider using “allowedOriginPatterns“ in
查看>>
Palo Alto Networks PAN-OS身份认证绕过导致RCE漏洞复现(CVE-2024-0012)
查看>>
pandas DataFrame 中的自定义浮点格式
查看>>
Pandas 读取具有浮点值的 csv 文件会导致奇怪的舍入和小数位数
查看>>
pandas 适用,但仅适用于满足条件的行
查看>>
Pandas-通过对列和索引的值求和来合并两个数据框
查看>>
pandas.read_csv()的详解-ChatGPT4o作答
查看>>
Pandas数据可视化怎么做?用实战案例告诉你!
查看>>
Pandas数据结构之DataFrame常见操作
查看>>
pandas整合多份csv文件
查看>>
pandas某一列转数组list
查看>>
pandas的to_sql方法中使用if_exists=‘replace‘
查看>>
Parallel.ForEach的基础使用
查看>>
parallels desktop for mac安装虚拟机 之parallelsdesktop密钥 以及 parallels desktop安装win10的办公推荐可以提高办公效率...
查看>>
PATA1038题解(需复习)
查看>>
Path does not chain with any of the trust anchors
查看>>
Path形状获取字符串型变量数据
查看>>
PAT甲级——1001 A+B Format (20分)
查看>>