Python3列表删除的三种方式实现
作者:hello-alien 发布时间:2021-03-26 17:55:55
1. 删除列表(list)的三种方式
(1).按照元素删除—remove()
直接删除具体某个元素,remove里面传递的是元素的值
从最左边开始寻找第一个符合要求的元素
remove函数没有结果返回
如果没有对应的元素,则抛出错误
my_list = [1, 2, 3, 4, 2, 5]
my_list.remove(2)
print(my_list)
# 结果
[1, 3, 4, 2, 5]
my_list = [1, 2, 3, 4, 2, 5]
my_list.remove(6)# 没有元素6,最终会抛出异常
print(my_list)
# 结果
Traceback (most recent call last):
File "/Users/alien_test.py", line 58, in <module>
my_list.remove(6)
ValueError: list.remove(x): x not in list
(2).按照索引删除—pop()
根据索引删除某个元素
pop执行完会返回对应元素的值
pip()中如果不传递索引,则删除最后一位元素
pop删除的索引,如果越界会抛出异常
# 根据索引删除元素
my_list = [1, 2, 3, 4, 2, 5]
item = my_list.pop(1)
print(my_list)
print(item)
# 结果
[1, 3, 4, 2, 5]
2# 元素2是对应索引为1的值
# 删除最后一个元素
my_list = [1, 2, 3, 4, 2, 5]
item = my_list.pop()
print(my_list)
print(item)
# 最终结果
[1, 2, 3, 4, 2]
5
# 越界抛出异常
my_list = [1, 2, 3, 4, 2, 5]
item = my_list.pop(8)
print(my_list)
print(item)
# 结果
Traceback (most recent call last):
File "/Users/test/alien_test.py", line 58, in <module>
item = my_list.pop(8)
IndexError: pop index out of range
(3).按照索引删除—del()
根据索引删除,最终结果没有返回值
索引越界抛出异常
my_list = [1, 2, 3, 4, 2, 5]
del my_list[1] #等同于 del(my_list[1])
print(my_list)
# 结果
[1, 3, 4, 2, 5]
my_list = [1, 2, 3, 4, 2, 5]
del my_list[8]
print(my_list)
# 异常结果
Traceback (most recent call last):
File "/Users/test/alien_test.py", line 58, in <module>
del my_list[8]
IndexError: list assignment index out of range
2. 删除元素引发的思考
(1).事故发生现场
【case 1:】
my_list = [1, 2, 2, 3, 2]
for item in my_list:
if item == 2:
my_list.remove(item)
print(my_list)
# [1, 3, 2]
【case 2:】
my_list = [1, 2, 2, 3, 2]
for index in range(len(my_list)):
if my_list[index] == 2:
my_list.pop(index)
print(my_list)
# 结果
Traceback (most recent call last):
File "/Users/test/alien_test.py", line 59, in <module>
if my_list[index] == 2:
IndexError: list index out of range
(2).列表----正序遍历的过程分析
my_list = [1, 2, 2, 3, 2]
for item in my_list:
print("item-------->", item)
if item == 2:
my_list.remove(item)
print(my_list)
# 结果:
item--------> 1
item--------> 2
item--------> 3
item--------> 2
[1, 3, 2]
【分析过程:】
如上过程,发现for循环的过程居然没有遍历所有的元素,打印的结果少一个索引位置为2的元素2
具体原因是,for循环的时候,列表的元素是动态变化的。具体可参考如下过程
step1:列表的遍历过程如下
列表的遍历是通过游标来控制列表的位置,从索引为0号位一直到最后一个位置,依次遍历
step2:列表的删除某个元素流程如下
当遍历到索引为1的位置时候,准备删除这个位置元素
删除完index=1这个元素之后,紧接着index=2的元素会向左移动到原始index=1的位置。此时,游标已经在index=1的位置。
下一次再遍历的时候,游标会自增1,变为从index=2开始。而此时index=2的元素是3,跳过了原始的index=2的元素2。
所以,如果有连续的相同的元素2,则会少遍历一次这个元素。如上2个案例,都是这个原因导致的问题。
(3).列表----倒序遍历的过程分析
my_list = [1, 2, 2, 3, 2]
for index in range(len(my_list) - 1, -1, -1):
item = my_list[index]
print("item-------->", index, "--->", item)
if item == 2:
my_list.pop(index)
print(my_list)
# 结果
item--------> 4 ---> 2
item--------> 3 ---> 3
item--------> 2 ---> 2
item--------> 1 ---> 2
item--------> 0 ---> 1
[1, 3]
1.通过倒序的遍历,可以把所有的2元素都删除了,倒序为什么能解决如上的问题?
2.倒序也会出现删除的元素的位置,被新元素占用的情况?
step1:列表倒序的遍历过程如下
step2:列表的删除某个元素流程如下
当遍历到索引为4的位置时候,准备删除这个位置元素
删除完索引index=4的元素之后
下一个遍历的索引是index=3,此时游标在index=3的位置,从元素3开始再遍历
当删除index=2的元素2的时候,因为这个元素前面的所有索引的位置都没有变动,所以再下一次,还能遍历到index=1的第一个2
最终,倒序最大的优势是,从后往前遍历,而前面所有元素的索引是没有变动的,固后续的遍历过程没有受是否删除元素的影响。这个是倒序最核心的优势!!!
3. 删除列表中重复的元素
(1).根据索引删除—(如上倒序的方式)
my_list = [1, 2, 2, 3, 2]
for index in range(len(my_list) - 1, -1, -1):
item = my_list[index]
print("item-------->", index, "--->", item)
if item == 2:
my_list.pop(index)
print(my_list)
(2).根据元素删除—(结果正确,但是过程是错误)
my_list = [1, 2, 2, 3, 2]
for index in range(len(my_list) - 1, -1, -1):
item = my_list[index]
print("item-------->", index, "--->", item)
if item == 2:
my_list.remove(item)
print("--->", my_list)
print(my_list)
# 结果
item--------> 4 ---> 2
---> [1, 2, 3, 2]# 此处倒序遍历,其实删除的是从左向右的第一个元素2
item--------> 3 ---> 2
---> [1, 3, 2]# 此除遍历的是第二个2,删除的也是第二个元素
item--------> 2 ---> 2
---> [1, 3]# 次数遍历的是最后一个2,删除的也是这个元素
item--------> 1 ---> 3
item--------> 0 ---> 1
[1, 3]
如上的方式不好的地方是:
倒序遍历了,但是最终删除的元素是从左向右排序的元素。如果出现多个相同的元素,则删除的不是当前遍历到的元素。
次方法, 慎重使用!!!
来源:https://hello-alien.blog.csdn.net/article/details/123737262
猜你喜欢
- 1.lower()将字符串中的大写字母转换成小写字母语法:str.lower()#举例:str1 = "LiBai is a bo
- 1. XML简介XML(eXtensible Markup Language)指可扩展标记语言,被设计用来传输和存储数据,已经日趋成为当前许
- 在学习OpenCV或者其他关于Python技术的时候,我们通常需要准备不同的Python环境,我选择了Anaconda作为我的Python环
- asp使用session来防止表单多次被提交的方法。formtest.asp' 表单文件<%Randomize&nb
- text-overflow这个属性真让Firefox折腾,虽然之前有写过Firefox通过XUL实现text-overflow:ellips
- 人们很容易忽视图像img标签的alt属性。然而,它的重要性也无法体现出来,它是有利于网页的accessibility and&nb
- 阅读上一篇:网马解密大讲堂——网马解密中级篇(Eval篇) 一.Document.write 函数简介:在Microsoft JScript
- 我的测试环境是2000sever ie6.0+sp4 MYIE1.31 (成功通过测试)关闭窗口的途径常用4种:1.双击左上角图标2.直接双
- 问题你写了一个装饰器作用在某个函数上,但是这个函数的重要的元信息比如名字、文档字符串、注解和参数签名都丢失了。解决方案任何时候你定义装饰器的
- 一、何谓ASP缓存/为什么要缓存当你的web站点采用asp技术建立的初期,可能感觉到的是asp * 页技术带来的便利性,以及随意修改性、自如
- Python 中 list.sort() 是列表中非常常用的排序函数, key 参数可以对单个属性进行排序。但是想要实现类似 sql 中 o
- 现在有一个xml,格式如下: <date> <item> <id> 1 </id> <
- 看了cragle的《有没有必要将网站Div+Css重构?》的文章,有一些想法不说不快,我也在文章的评论里提到曾经开除过两个执着使用div技术
- 一、在CentOS上安装Python31.下载Python3.10源代码文件下载地址:https://www.python.org/down
- 我有大量的重要数据要从SQL Server导出到Access或Excel文件中去,手工做太麻烦,还有其它的好办法吗?有,我们在 SQL Se
- 目录1 标准化2 归一化3 正则化4 离散化5 白化 机器
- 概述 -------------------------------------------------------------------
- SQL Server数据库的六个实用技巧:(一)挂起操作在安装Sql或sp补丁的时候系统提示之前有挂起的安装操作,要求重启,这里往往重启无用
- 本文实例主要实现Python中的文件复制操作,有两种方法,具体实现代码如下所示:#coding:utf-8 # 方法1:使用read()和w
- Oracle shutdown的时候突然断电,导致使用sql/plus启动时无法连接到数据库,具体描述为:connection can no