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():删除列表所有元素