基于Python中Remove函数的用法讨论


Posted in Python onDecember 11, 2020

前几天在进行写程序时碰到这样一个问题

a=['a','b','c','d']

b=['c','d','e','f']

需要将数组a中元素,在数组b中出现过都删除。第一次写出程序如下:

a=['a','b','c','d']
b=['c','d','e','f']
for x in a:
 if x in b:
 a.remove(x)
print (a)

最后的输出结果为

基于Python中Remove函数的用法讨论

出现这样的结果,当时感觉很诧异。但立马细细一想,立马明白了其中的原因。

当x='c'时,此时满足if条件语句,执行if下的语句:a.remove(x),也就是将'c'元素从a数组中删除。

删除之后,remove函数并没有执行结束。而是将a数组中索引号大于删除元素索引号的所有元素依次前一位。

此时,x指向a[2],a数组当前的状态为:['a','b','d'],a[2]中存储的为元素'd'。

remove函数返回后,继续执行for循环,x指向数组的下一个索引。

因此导致了'd'元素没有与数组b进行比较。

后续,将程序进行了如下修改:

a=['a','b','c','d']
c=['a','b','c','d']
b=['c','d','e','f']
 
for x in a:
 if x in b:
 c.remove(x)
print (c)

程序运行结果如下:

基于Python中Remove函数的用法讨论

虽然问题不是很难,但是这个细节问题一定要把握。

补充知识:Python列表的remove方法的注意事项

基于Python中Remove函数的用法讨论

为何没有删除列表中的全部元素?

解释:

按照执行顺序,第一个空格被删除之后,后面的元素会前移(变成['空格','空格','12','23']),指针下一次会指向新列表的第二个元素(即初始状态的第三个空格),从而初始状态的第二个空格被跳过了,初始第三个空格被删除,接着后面的元素又再次前移(变成['空格','12','23']),指针指向新列表的第三个元素,即初始状态的第5个元素23,然后23被删除了,因此只剩下['空格','12']

如果想排除初始列表中的部分元素,如何实现?

由上面的情况知道,在遍历列表的同时对列表执行删除操作,会造成意外的结果,那么对初始列表进行遍历,对初始的列表的副本执行删除操作呢?

基于Python中Remove函数的用法讨论

以上结果显示,没有得到预期效果。为什么?

问题出在copy=ls这一句,这里仅仅是使得copy与ls指向了同一片内存(即浅拷贝,shallow copy),并没有执行【开辟一片新内存,并且ls内存中的内容复制到新内存,然后使copy指向新开辟的内存,即深拷贝,deep copy】这一系列操作。因此对copy执行的remove操作,和对遍历ls列表,实质上还是都是针对同一片内存进行操作,因此结果上一个例子类似。

若想解决这一问题,有3个办法法:

(1)

ls=[' ',' ',' ','12','23','abc','aa']

copy=[' ',' ',' ','12','23','abc','aa']

这一办法对于已知列表的所有元素,且元素数量较少,结构较简单时可行,其他情况下不可行。

(2)引入copy模块的deepcopy方法:

基于Python中Remove函数的用法讨论

Python列表的remove方法的注意事项

(3)另外准备一个空列表,遍历初始列表时,将符合条件的元素逐一加入到空列表当中(利用列表的append方法)。

这种方法,思路上与remove方法相反,但执行的操作差不多,时间复杂度也与remove方法差不多,无需引入copy模块。

另外,对于列表的remove方法,python基础教程第二版给出的说明是:

remove方法用于移除列表中某个值的第一个匹配项:

>>>x=['to','be','or','not','to','be']
>>>x.remove('be')
>>>x
['to','or','not','to','be']

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。如有错误或未考虑完全的地方欢迎留言讨论,望不吝赐教。

Python 相关文章推荐
asyncio 的 coroutine对象 与 Future对象使用指南
Sep 11 Python
Python新手入门最容易犯的错误总结
Apr 24 Python
Python之py2exe打包工具详解
Jun 14 Python
python实现日常记账本小程序
Mar 10 Python
python读取文本中数据并转化为DataFrame的实例
Apr 10 Python
Python运维自动化之nginx配置文件对比操作示例
Aug 29 Python
Python 变量类型详解
Oct 10 Python
在python中利用opencv简单做图片比对的方法
Jan 24 Python
Python类的继承、多态及获取对象信息操作详解
Feb 28 Python
Python Opencv 通过轨迹(跟踪)栏实现更改整张图像的背景颜色
Mar 09 Python
Python基础之赋值,浅拷贝,深拷贝的区别
Apr 30 Python
Python实现学生管理系统并生成exe可执行文件详解流程
Jan 22 Python
在 Python 中使用 7zip 备份文件的操作
Dec 11 #Python
Python文件名匹配与文件复制的实现
Dec 11 #Python
Python: glob匹配文件的操作
Dec 11 #Python
Python Socket多线程并发原理及实现
Dec 11 #Python
python 实现Harris角点检测算法
Dec 11 #Python
使用python画出逻辑斯蒂映射(logistic map)中的分叉图案例
Dec 11 #Python
Python3 用matplotlib绘制sigmoid函数的案例
Dec 11 #Python
You might like
全文搜索和替换
2006/10/09 PHP
php 问卷调查结果统计
2015/10/08 PHP
php禁用函数设置及查看方法详解
2016/07/25 PHP
PHP删除二维数组中相同元素及数组重复值的方法示例
2017/05/05 PHP
PHP编程实现微信企业向用户付款的方法示例
2017/07/26 PHP
PHPExcel 修改已存在Excel的方法
2018/05/03 PHP
THINKPHP5.1 Config的配置与获取详解
2020/06/08 PHP
一起来写段JS drag拖动代码
2010/12/09 Javascript
javaScript函数中执行C#代码中的函数方法总结
2013/08/07 Javascript
jquery删除提示框弹出是否删除对话框
2014/01/07 Javascript
node.js适合游戏后台开发吗?
2014/09/03 Javascript
在 Express 中使用模板引擎
2015/12/10 Javascript
JavaScript如何实现组合列表框中元素移动效果
2016/03/01 Javascript
js判断所有表单项不为空则提交表单的实现方法
2016/09/09 Javascript
vue货币过滤器的实现方法
2017/04/01 Javascript
JavaScript数据结构与算法之检索算法实例分析【顺序查找、最大最小值、自组织查询】
2019/02/22 Javascript
JavaScript静态作用域和动态作用域实例详解
2019/06/17 Javascript
layer.js open 隐藏滚动条的例子
2019/09/05 Javascript
基于JavaScript实现贪吃蛇游戏
2020/03/16 Javascript
[01:07]2015国际邀请赛 中国区预选赛精彩回顾
2015/06/15 DOTA
深入理解Python中命名空间的查找规则LEGB
2015/08/06 Python
OpenCV2.3.1+Python2.7.3+Numpy等的配置解析
2018/01/05 Python
使用python将请求的requests headers参数格式化方法
2019/01/02 Python
python之生成多层json结构的实现
2020/02/27 Python
如何使用Python调整图像大小
2020/09/26 Python
python 利用matplotlib在3D空间绘制二次抛物面的案例
2021/02/06 Python
纯css3制作网站后台管理面板
2014/12/30 HTML / CSS
西班牙网上书店:Casa del Libro
2016/11/01 全球购物
沃尔玛旗下墨西哥超市:Bodega Aurrera
2020/11/13 全球购物
大学生就业自我鉴定
2013/10/26 职场文书
新闻专业本科生的自我评价分享
2013/11/20 职场文书
竞聘上岗演讲稿范文
2014/01/10 职场文书
开业庆典主持词
2014/03/21 职场文书
2015年酒店服务员工作总结
2015/05/18 职场文书
经营场所证明范本
2015/06/19 职场文书
Python机器学习之逻辑回归
2021/05/11 Python