如何从列表中删除第一项?
[0, 1, 2, 3] → [1, 2, 3]
如何从列表中删除第一项?
[0, 1, 2, 3] → [1, 2, 3]
当前回答
有一种数据结构叫做双端队列或双端队列,它比列表更快更有效。您可以使用您的列表并将其转换为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。试试吧!
其他回答
有一种数据结构叫做双端队列或双端队列,它比列表更快更有效。您可以使用您的列表并将其转换为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。试试吧!
>>> x = [0, 1, 2, 3, 4]
>>> x.pop(0)
0
这里有更多。
如果你正在使用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]
拆包的任务:
您可以使用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]
你可以使用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