リストから最初のアイテムを削除する方法は?


773

[0, 1, 2, 3, 4]作成したいリストがあります[1, 2, 3, 4]。どうすればいいですか?

回答:


1259

Pythonリスト

list.pop(index)

>>> 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'])
  • リストの左端からポップするより高いパフォーマンスを提供します

リストと同じ意味を持つ負のインデックスを使用することもできます。
ガブリエルデヴィレール

189

スライス:

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

これは実際には元のサブセットを返しますが、変更はしません。


17
x空の場合、x=x[1:]文句を言わずに空のままにします。x.pop(0)空のリストをスローしますx。ときどき投げるのが好きなこともあります。リストに少なくとも要素があるという仮定が間違っている場合は、通知を受け取ることができます。
16

これをありがとう!破壊的ではないので、これはより良い答えです、イモ
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) xだろう0



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つのアプローチです。
頂点2014

1
はい、他の回答に勝る別のアプローチ。それを行う方法はいくつもあります。答えを出してみませんa.remove(a[1-1])か?それは別の方法です。
Ned Batchelder

2
私のポイントは、あなたの答えは他の答えよりも悪く、それを推奨するものは何もないということです。この回答を他の回答よりも使用する理由はありません。「別の方法」だからといってここに追加する理由にはなりません。
Ned Batchelder 2014

4
@NedBatchelderあなたのポイントは議論の余地があります。これは、この特定のタスクに固有の、Pythonのリストで使用できる追加のメソッドであり、完全を期すために注意する必要があります。一方、考案されたBS a [1-1]の例はそうではありません。言うまでもなく、彼の答えは「他の答えよりも悪い」ものではありません。
Hejazzman 2014年

8
私は私の質問を支持します。これは奇妙で不自然なようで、推奨するものは何もありません。実際、最初の文は誤解を招くものですlist.remove(a[i])。これは、i番目の要素をで削除できないためです。値が重複していると、同じ値を持つ以前の要素が見つかり、i番目ではなくその要素が削除される場合があります。
Ned Batchelder 2014年

4

あなたが作業している場合numpyのあなたが使用する必要があり、削除方法を:

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は、リストのいずれかの側または特定のインデックスに要素を挿入するなどの非常に便利な機能も提供します。両端キューを回転または反転することもできます。試してみる!!

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.