我有列表[0, 1, 2, 3, 4]
我希望将其列入[1, 2, 3, 4]
。我该怎么做?
答案 0 :(得分:1018)
<强> list.pop(指数)强>
>>> l = ['a', 'b', 'c', 'd']
>>> l.pop(0)
'a'
>>> l
['b', 'c', 'd']
>>>
del list [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'])
答案 1 :(得分:165)
切片:
x = [0,1,2,3,4]
x = x[1:]
哪个实际上会返回原始的子集但不会修改它。
答案 2 :(得分:34)
>>> x = [0, 1, 2, 3, 4]
>>> x.pop(0)
0
有关此here的详情。
答案 3 :(得分:27)
你会这样做
l = [0, 1, 2, 3, 4]
l.pop(0)
或l = l[1:]
优点和缺点
使用pop可以检索值
说x = l.pop(0)
x
将是0
答案 4 :(得分:25)
使用列表切片,请参阅有关lists的Python教程以获取更多详细信息:
>>> l = [0, 1, 2, 3, 4]
>>> l[1:]
[1, 2, 3, 4]
答案 5 :(得分:14)
然后删除它:
x = [0, 1, 2, 3, 4]
del x[0]
print x
# [1, 2, 3, 4]
答案 6 :(得分:7)
您可以使用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
答案 7 :(得分:5)
您还可以使用list.remove(a[0])
pop
清除列表中的第一个元素。
>>>> a=[1,2,3,4,5]
>>>> a.remove(a[0])
>>>> print a
>>>> [2,3,4,5]
答案 8 :(得分:3)
有一个称为“ deque”或双头队列的数据结构,它比列表更快,更高效。您可以使用列表并将其转换为双端队列,并在其中进行所需的转换。您还可以将双端队列转换回列表。
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还提供了非常有用的功能,例如将元素插入到列表的任一侧或任何特定的索引。您也可以旋转或反转双端队列。试试看!!
答案 9 :(得分:2)