Як видалити перший елемент зі списку?


Відповіді:


1256

Список Python

list.pop (індекс)

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

del list [покажчик]

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

Вони обидва змінюють ваш початковий список.

Інші пропонують використовувати нарізку:

  • Копіює список
  • Може повернути підмножину

Крім того, якщо ви виконуєте багато попсів (0), вам слід поглянути на collection.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

Дякую за це! Це краща відповідь, imo, тому що це не руйнує
Хе Джин


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
ОП не запитує про найкращий спосіб це зробити. Це просто інший підхід для досягнення того ж!
вершина

1
Так, ще один підхід, який не має переваги перед іншими відповідями. Існує будь-яка кількість способів зробити це. Чому б не дати відповідь a.remove(a[1-1])? Це ще один спосіб.
Нед Батчелдер

2
Моя думка, що ваша відповідь гірша, ніж відповіді інших, і не має нічого її рекомендувати. Немає підстав використовувати цю відповідь над іншими. Просто тому, що це "інший спосіб", це не привід додавати його сюди.
Нед Батчелдер

4
@NedBatchelder Ваша думка суперечить. Це додатковий метод, доступний для списків на Python, характерних для даної конкретної задачі, і заради повноти слід зазначити. Надуманий BS [1-1] приклад, з іншого боку, це не так. Не кажучи вже про те, що його відповідь ні в якому разі не «гірша за інші відповіді».
Hejazzman

8
Я стою біля свого запитання: це здається дивним і надуманим, і не має що рекомендувати. Насправді, перше речення вводить в оману, оскільки ви не можете видалити i-й елемент за допомогою list.remove(a[i]). При повторюваних значеннях він може знайти попередній елемент з тим же значенням і видалити цей замість i'th.
Нед Батчелдер


1

Існує структура даних під назвою "deque" або подвійне закінчення черги, яке швидше і ефективніше, ніж список. Ви можете використовувати свій список і перетворити його на 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 також пропонує дуже корисні функції, такі як вставлення елементів у будь-яку сторону списку або в будь-який конкретний індекс. Ви також можете обертати або повертати деке. Спробувати!!

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.