Python 列表的操作(元素的删除)
del:根据索引值删除元素
del 可以删除列表中的单个元素,格式为:
del listname[index]
其中,listname 表示列表名称,index 表示元素的索引值。
del 也可以删除中间一段连续的元素,格式为:
del listname[start : end]
其中,start 表示起始索引,end 表示结束索引。del 会删除从索引 start 到 end 之间的元素,不包括 end 位置的元素。
pop():根据索引值删除元素
Python pop() 方法用来删除列表中指定索引处的元素,具体格式如下:
listname.pop(index)
其中,listname 表示列表名称,index 表示索引值。如果不写 index 参数,默认会删除列表中的最后一个元素,类似于数据结构中的“出栈”操作。
remove():根据元素值进行删除
除了 del 关键字,Python 还提供了 remove() 方法,该方法会根据元素本身的值来进行删除操作。
需要注意的是,remove() 方法只会删除第一个和指定值相同的元素,而且必须保证该元素是存在的,否则会引发 ValueError 错误。
干货来了:
实际运用中我们大都是在循环中删除列表里的元素
s=['python','python','小韩','小柯','小明',7089143]
for i in s:
if i=='python':
s.remove(i)
print(s)
#打印输出:
>> ['python', '小韩', '小柯', '小明', 7089143]
咦????为什么只删除了1个元素('python')呢?
接着往下看:
s=['python','python','小韩','小柯','小明',7089143]
for i in s:
s.remove(i)
print(s)
#打印输出:
>> ['python', '小柯', 7089143]
??????为什么不是[]呢?
主要因为remove改变了list长度和每一个元素的位置
也就是说当条件成立是,第一次循环s.remove(i)删除了第一个元素,
第二次循环时由于列表被改变为['小韩', '小柯', '小明', 7089143]那么i=列表s[1]='小柯',
造成了原列表s中的元素'小韩'被跳过,以此类推就出现了上述两种疑问。
那怎么解决上述问题呢?下面我简单介绍两种方法(其实有很多方法,这里我只简单搞两种)
问题解决:
1、倒序
2、in 函数
clear():删除列表所有元素
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY