python版本删除删除

在Python的列表中利用remove()方法删除元素的教程
投稿:goldensun
字体:[ ] 类型:转载 时间:
这篇文章主要介绍了在Python的列表中利用remove()方法删除元素的教程,是Python入门中的基础知识,注意其和pop()方法的区别,需要的朋友可以参考下
&remove()方法从列表中删除第一个obj。
以下是remove()方法的语法:
list.remove(obj)
&&& obj -- 这是可以从列表中移除该对象
此方法不返回任何值,但从列表中删除给定的对象
下面的例子显示了remove()方法的使用
#!/usr/bin/python
aList = [123, 'xyz', 'zara', 'abc', 'xyz'];
aList.remove('xyz');
print "List : ", aL
aList.remove('abc');
print "List : ", aL
当我们运行上面的程序,它会产生以下结果:
List : [123, 'zara', 'abc', 'xyz']
List : [123, 'zara', 'xyz']
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具用python删除数据-python-电脑编程网用python删除数据作者:佚名 和相关&&
import os, sys,datetime,timefrom stat&&import *path='c:\\test\\'path2='c:\\test\\'filelist=[]filelist=os.listdir(path)for i in range(len(filelist)):& & & & t1 = time.gmtime(os.stat(path+filelist)[ST_MTIME])&&#get file's mofidy time& & & & t11 =&&time.strftime('%Y-%m-%d',t1)& & & & year,month,day=t11.split('-')& & & & t111= datetime.datetime(int(year),int(month),int(day))& & & & & & & & t2 = time.gmtime()& & & & t22 =&&time.strftime('%Y-%m-%d',t2)& & & & year,month,day=t22.split('-')& & & & t222= datetime.datetime(int(year),int(month),int(day))& & & & & & & & days =&&(t222-t111).days& & & & if days&5 :&&# if over 5 days then remove file& & & & & & & & try:& & & & & & & & & & & & os.remove(path+filelist)& & & & & & & & & & & & log=datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')+"&&remove "+path+filelist+"&&success \n"& & & & & & & & except:& & & & & & & & & & & & log=datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')+"&&remove "+path+filelist+"&&fail \n"& & & & & & & & & & & & & & & & fTemp=open(path2+"remove_file.log", 'a')& & & & & & & & & & & & fTemp.write(log)
相关资料:|||||||用python删除数据来源网络,如有侵权请告知,即处理!编程Tags:                &                    Python的list循环遍历中,删除数据的正确方法
初学Python,遇到过这样的问题,在遍历list的时候,删除符合条件的数据,可是总是报异常,代码如下: num_list = [1, 2, 3, 4, 5]print(num_list)for i in range(len(num_list)): if num_list[i] == 2: num_list.p
初学Python,遇到过这样的问题,在遍历list的时候,删除符合条件的数据,可是总是报异常,代码如下:
num_list = [1, 2, 3, 4, 5]
print(num_list)
for i in range(len(num_list)):
if num_list[i] == 2:
num_list.pop(i)
print(num_list[i])
print(num_list)
会报异常:&IndexError: list index out of range
原因是在删除list中的元素后,list的实际长度变小了,但是循环次数没有减少,依然按照原来list的长度进行遍历,所以会造成索引溢出。
于是我修改了代码如下:
num_list = [1, 2, 3, 4, 5]
print(num_list)
for i in range(len(num_list)):
if i &= len(num_list):
if num_list[i] == 2:
num_list.pop(i)
print(num_list[i])
print(num_list)
这回不会报异常了,但是打印结果如下:
[1, 2, 3, 4, 5]
[1, 3, 4, 5]
[Finished in 0.128s]
虽然最后,list中的元素[2]确实被删除掉了,但是,在循环中的打印结果不对,少打印了[3]。
思考了下,知道了原因,当符合条件,删除元素[2]之后,后面的元素全部往前移,于是[3, 4, 5]向前移动,那么元素[3]的索引,就变成了之前[2]的索引(现在[3]的下标索引变为1了),后面的元素以此类推。可是,下一次for循环的时候,是从下标索引2开始的,于是,取出了元素[4],就把[3]漏掉了。
把代码修改成如下,结果一样,丝毫没有改观:
num_list = [1, 2, 3, 4, 5]
print(num_list)
for item in num_list:
if item == 2:
num_list.remove(item)
print(item)
print(num_list)
既然知道了问题的根本原因所在,想要找到正确的方法,也并不难,于是我写了如下的代码:
num_list = [1, 2, 3, 4, 5]
print(num_list)
while i & len(num_list):
if num_list[i] == 2:
num_list.pop(i)
print(num_list[i])
print(num_list)
执行结果,完全正确:
[1, 2, 3, 4, 5]
[1, 3, 4, 5]
[Finished in 0.122s]
我的做法是,既然用for循环不行,那就换个思路,用while循环来搞定。每次while循环的时候,都会去检查list的长度(&i &&len(num_list)&),这样,就避免了索引溢出,然后,在符合条件,删除元素[2]之后,手动把当前下标索引-1,以使下一次循环的时候,通过-1后的下标索引取出来的元素是[3],而不是略过[3]。
当然,这还不是最优解,所以,我搜索到了通用的解决方案:1、倒序循环遍历;2、遍历拷贝的list,操作原始的list。
1、倒序循环:
num_list = [1, 2, 3, 4, 5]
print(num_list)
for i in range(len(num_list)-1, -1, -1):
if num_list[i] == 2:
num_list.pop(i)
print(num_list[i])
print(num_list)
执行结果完全正确。
2、&遍历拷贝的list,操作原始的list
num_list = [1, 2, 3, 4, 5]
print(num_list)
for item in num_list[:]:
if item == 2:
num_list.remove(item)else:
print(item)
print(num_list)
原始的list是num_list,那么其实,num_list[:]是对原始的num_list的一个拷贝,是一个新的list,所以,我们遍历新的list,而删除原始的list中的元素,则既不会引起索引溢出,最后又能够得到想要的最终结果。此方法的缺点可能是,对于过大的list,拷贝后可能很占内存。那么对于这种情况,可以用倒序遍历的方法来实现。
IndexError: list index out of range
(责任编辑:最模板)
------分隔线----------------------------
在Mac上用Python脚本测试无疑是最爽的,然而我们组一个:ox:人写的...
在日常运维中,如果涉及到用户管理,就一定会用到给用户设置...
在python中使用单例模式非常的容易。 你在一个模块中初始化一个...
这次拿到近亿条日志数据,千万级数据已经是关系型数据库的查...
归并排序原理:将一个数组分成由左右两个数组,如果左右两个...
CopyRight (C)
最模板 , 深圳奇好科技有限公司 All Rights Reserved.python的列表list可以用for循环进行遍历,实际开发中发现一个问题,就是遍历的时候删除会出错,例如
l = [1,2,3,4]
for i in l:
&& &if i != 4:
&& &l.remove(i)
这几句话本来意图是想清空列表l,只留元素4,但是实际跑起来并不是那个结果。再看下面,利用index来遍历删除列表l
l = [1, 2, 3, 4]for i in range(len(l)):& & if l[i] == 4:& && &&&del l[i]print l
这样没问题,可以遍历删除,但是列表l如果变为 l = [1,2,3,4,5]
如果还是按照上面的方法,设想一下,range开始的范围是0-4,中间遍历的时候删除了一个元素4,这个时候列表变成了= [1,2,3,5],这时候就会报错了,提示下标超出了数组的表示,原因就是上面说的遍历的时候删除了元素
所以python的list在遍历的时候删除元素一定要小心
可以使用filter过滤返回新的list
l = [1,2,3,4]
l = filter(lambda x:x !=4,l)
这样可以安全删除l中值为4的元素了,filter要求两个参数,第一个是规则函数,第二个参数要求输入序列,而lambda这个函数的作用就是产生一个函数,是一种紧凑小函数的写法,一般简单的函数可以这么些
或者可以这样
l = [1,2,3,4]
l = [ i for i in l if i !=4]//同样产生一个新序列,复值给l
或者干脆建立新的list存放要删除的元素
l = [1,2,3,4]
dellist = []
for i in l:
&& &if i == 4:
&& & & &dellist.append(i)
for i in dellist:
&& &l.remove(i)
这样也能安全删除元素
所以要遍历的时候删除元素一定要小心,特别是有些操作并不报错,但却没有达到预期的效果
上面说到产生新序列,赋值等等,用python的id()这个内置函数来看对象的id,可以理解为内存中的地址,所以有个简要说明
l = [1,2,3,4]
l.remove(1)
print l//肯定是[2,3,4]
print ll//这里会是什么?
如果用id函数查看的话就发现
print id(l),id(ll)
打印出相同的号码,说明他们其实是一个值,也就是说上面的print ll将和l打印的一样,所以python有这种性质,用的时候注意一下就行了
阅读(...) 评论()}

我要回帖

更多关于 pip biopython 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信