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

[0, 1, 2, 3]   →   [1, 2, 3]

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

这里有更多。


切片:

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

它实际上会返回原始的子集,但不会修改它。


使用列表切片,请参阅Python关于列表的教程了解更多详细信息:

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

你会这样做

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

Or l = l[1:]

利与弊

使用pop可以检索值

假设x = l.pop(0) X等于0


您可以在这里找到一个有用的列表函数的简短集合。

list.pop(索引)

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

的列表[index]

>>> 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'])

提供从列表左端弹出的更高性能


然后删除它:

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

你也可以使用list.remove(a[0])来弹出列表中的第一个元素。

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

你可以使用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

如果你正在使用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]

有一种数据结构叫做双端队列或双端队列,它比列表更快更有效。您可以使用您的列表并将其转换为deque并在其中执行所需的转换。你也可以将deque转换回list。

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还提供了非常有用的函数,如将元素插入到列表的任意一侧或任何特定的索引中。您还可以旋转或反转deque。试试吧!


拆包的任务:

您可以使用PEP 3132中提到的开箱分配。

解决方案:

你应该试着像下面这样拆包:

>>> l = [0, 1, 2, 3, 4]
>>> _, *l = l
>>> l
[1, 2, 3, 4]

解释:

PEP 3132中提到:

此PEP建议对可迭代解包语法进行更改,允许 指定一个“全能”名称,它将被分配一个包含所有项目的列表 没有被指定为“常规”名称的。 一个例子胜过千言万语: a, *b, c = range(5) > > >一个 0 > > > c 4 > > > b [1,2,3]


这对我来说是有效的,而不是像下面这样使用pop,这当然会是0,因为pop的结果/返回值

>>> x = [0, 1, 2, 3].pop(0)
>>> x
0

使用下面的方法将跳过第一个值:

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