当你想在Python中清除一个列表时,有什么理由去做比这两行更复杂的事情吗?

old_list = []
old_list = list()

我问这个问题的原因是我刚刚在一些正在运行的代码中看到了这个:

del old_list[ 0:len(old_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[:] = []

执行alist =[]并不清除列表,只是创建一个空列表并将其绑定到变量list。如果旧的列表有其他变量绑定,那么它将仍然存在。

要真正清除列表,你可以使用以下任何一种方法:

最清楚()Python 3.3+,最清楚 del alist [:] alist[:] = [] alist * 0更快

更多细节请参见可变序列类型文档页。

在我看来,del会把内存还给你,而分配一个新的列表将使旧的列表只在gc运行.matter时被删除。

这对于大型列表可能很有用,但对于小型列表则可以忽略不计。

编辑:作为算法,这并不重要。

请注意,

del old_list[ 0:len(old_list) ]

等于

del old_list[:]

在以下两种情况下,您可能需要清除列表:

你想在你的代码中进一步使用名称old_list; 你希望旧的列表尽快被垃圾收集,以释放一些内存;

在情况1中,你只要继续做作业

    old_list = []    # or whatever you want it to be equal to

在情况2中,del语句将减少old list所指向的list对象的引用计数。如果列表对象仅由名称old_list at指向,则引用计数将为0,并且该对象将被释放用于垃圾收集。

    del old_list

有一个非常简单的方法来清除python列表。使用del list_name[:]。

例如:

>>> a = [1, 2, 3]
>>> b = a
>>> del a[:]
>>> print a, b
[] []