如何从列表中删除第一个项目?


772

我有表[0, 1, 2, 3, 4],我想将它做成[1, 2, 3, 4]。我该怎么办?

Answers:


1256

Python清单

list.pop(索引)

>>> l = ['a', 'b', 'c', 'd']
>>> l.pop(0)
'a'
>>> l
['b', 'c', 'd']
>>> 

删除列表[索引]

>>> l = ['a', 'b', 'c', 'd']
>>> del l[0]
>>> l
['b', 'c', 'd']
>>> 

这些都将修改您的原始列表。

其他人建议使用切片:

  • 复制清单
  • 可以返回一个子集

另外,如果要执行许多pop(0),则应查看collections.deque

from collections import deque
>>> l = deque(['a', 'b', 'c', 'd'])
>>> l.popleft()
'a'
>>> l
deque(['b', 'c', 'd'])
  • 从列表的左端提供更高的性能

您还可以使用负索引,其含义与列表相同。
加布里埃尔·德维勒

189

切片:

x = [0,1,2,3,4]
x = x[1:]

这实际上将返回原始的子集,但不会对其进行修改。


16
如果x为空,x=x[1:]则将其保留为空而不会抱怨。x.pop(0)会抛出一个空清单x。有时抛出的是人们想要的:如果假设列表中至少有一个元素是错误的,则可能希望得到通知。
ead 2016年

谢谢你!imo,这是一个更好的答案,因为它没有破坏性
Hee Jin


29

使用列表切片,请参阅有关列表的Python教程以获取更多详细信息:

>>> l = [0, 1, 2, 3, 4]
>>> l[1:]
[1, 2, 3, 4]

29

你会这样做

l = [0, 1, 2, 3, 4]
l.pop(0)

要么 l = l[1:]

利弊

使用pop可以获取值

x = l.pop(0) x0


15

然后将其删除:

x = [0, 1, 2, 3, 4]
del x[0]
print x
# [1, 2, 3, 4]

8

您可以list.reverse()用来反转列表,然后list.pop()删除最后一个元素,例如:

l = [0, 1, 2, 3, 4]
l.reverse()
print l
[4, 3, 2, 1, 0]


l.pop()
0
l.pop()
1
l.pop()
2
l.pop()
3
l.pop()
4

5

您也可以使用list.remove(a[0])pop删除列表中的第一个元素。

>>>> a=[1,2,3,4,5]
>>>> a.remove(a[0])
>>>> print a
>>>> [2,3,4,5]

3
OP并未询问最佳方法。这只是达到相同目的的另一种方法!
顶点

1
是的,另一种方法没有其他答案的优势。有许多方法可以做到这一点。为什么不给出答案a.remove(a[1-1])?那是另一种方式。
Ned Batchelder 2014年

2
我的观点是,您的答案要比其他答案差,没有什么可推荐的。没有理由在其他答案上使用此答案。仅仅因为它是“另一种方式”并不是在这里添加它的理由。
Ned Batchelder

4
@NedBatchelder您的观点没有意义。这是特定于此特定任务的Python列表中可用的额外方法,为完整起见,应注意这一点。另一方面,人为的BS a [1-1]示例并非如此。更不用说他的回答绝不是“比其他答案更糟糕”。
Hejazzman 2014年

8
我支持我的问题:这似乎很奇怪和人为,没有什么可推荐的。实际上,第一句话具有误导性,因为您无法使用删除第i个元素list.remove(a[i])。对于重复的值,它可能会找到一个具有相同值的较早元素,并删除该元素而不是第i个元素。
Ned Batchelder 2014年

4

如果使用numpy,则需要使用delete方法:

import numpy as np

a = np.array([1, 2, 3, 4, 5])

a = np.delete(a, 0)

print(a) # [2 3 4 5]

1

有一个称为“双端队列”或双头队列的数据结构,它比列表更快,更高效。您可以使用列表并将其转换为双端队列,并在其中进行所需的转换。您也可以将双端队列转换回列表。

import collections
mylist = [0, 1, 2, 3, 4]

#make a deque from your list
de = collections.deque(mylist)

#you can remove from a deque from either left side or right side
de.popleft()
print(de)

#you can covert the deque back to list
mylist = list(de)
print(mylist)

Deque还提供了非常有用的功能,例如将元素插入列表的任一侧或任何特定的索引。您也可以旋转或反转双端队列。试试看!!

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.