当你想在Python中清除一个列表时,有什么理由去做比这两行更复杂的事情吗?
old_list = []
old_list = list()
我问这个问题的原因是我刚刚在一些正在运行的代码中看到了这个:
del old_list[ 0:len(old_list) ]
当你想在Python中清除一个列表时,有什么理由去做比这两行更复杂的事情吗?
old_list = []
old_list = list()
我问这个问题的原因是我刚刚在一些正在运行的代码中看到了这个:
del old_list[ 0:len(old_list) ]
当前回答
在我看来,del会把内存还给你,而分配一个新的列表将使旧的列表只在gc运行.matter时被删除。
这对于大型列表可能很有用,但对于小型列表则可以忽略不计。
编辑:作为算法,这并不重要。
请注意,
del old_list[ 0:len(old_list) ]
等于
del old_list[:]
其他回答
执行alist =[]并不清除列表,只是创建一个空列表并将其绑定到变量list。如果旧的列表有其他变量绑定,那么它将仍然存在。
要真正清除列表,你可以使用以下任何一种方法:
最清楚()Python 3.3+,最清楚 del alist [:] alist[:] = [] alist * 0更快
更多细节请参见可变序列类型文档页。
另一个工作良好的解决方案是创建一个空列表作为引用空列表。
empt_list = []
例如,您有一个a_list =[1,2,3]的列表。要清除它,只需执行以下命令:
a_list = list(empt_list)
这将使a_list成为一个空列表,就像empt_list一样。
有一个非常简单的方法来清除python列表。使用del list_name[:]。
例如:
>>> a = [1, 2, 3]
>>> b = a
>>> del a[:]
>>> print a, b
[] []
清除一个列表将影响同一列表的所有其他引用。
例如,这个方法不会影响其他引用:
>>> a = [1, 2, 3]
>>> b = a
>>> a = []
>>> print(a)
[]
>>> print(b)
[1, 2, 3]
但这一个有:
>>> a = [1, 2, 3]
>>> b = a
>>> del a[:] # equivalent to del a[0:len(a)]
>>> print(a)
[]
>>> print(b)
[]
>>> a is b
True
你还可以:
>>> a[:] = []
在我看来,del会把内存还给你,而分配一个新的列表将使旧的列表只在gc运行.matter时被删除。
这对于大型列表可能很有用,但对于小型列表则可以忽略不计。
编辑:作为算法,这并不重要。
请注意,
del old_list[ 0:len(old_list) ]
等于
del old_list[:]