Mam listę [0, 1, 2, 3, 4]
, do której chciałbym się dostać [1, 2, 3, 4]
. Jak mam to zrobić?
772
list.pop (indeks)
>>> l = ['a', 'b', 'c', 'd']
>>> l.pop(0)
'a'
>>> l
['b', 'c', 'd']
>>>
del list [indeks]
>>> l = ['a', 'b', 'c', 'd']
>>> del l[0]
>>> l
['b', 'c', 'd']
>>>
Oba modyfikują oryginalną listę.
Inni sugerują stosowanie krojenia:
Ponadto, jeśli wykonujesz wiele popów (0), powinieneś spojrzeć na kolekcje.deque
from collections import deque
>>> l = deque(['a', 'b', 'c', 'd'])
>>> l.popleft()
'a'
>>> l
deque(['b', 'c', 'd'])
Krajanie na plastry:
Który faktycznie zwróciłby podzbiór oryginału, ale go nie zmodyfikował.
źródło
x
jest pusty,x=x[1:]
pozostawiłby go pusty bez narzekania.x.pop(0)
rzuciłby na pustą listęx
. Czasami chce się rzucać: jeśli założenie, że na liście jest przynajmniej element, jest błędne, ktoś może chcieć otrzymać powiadomienie.Więcej na ten temat tutaj .
źródło
W przypadku wycinania list więcej szczegółów znajdziesz w samouczku Python na temat list :
źródło
po prostu to zrobiłbyś
lub
l = l[1:]
Plusy i minusy
Za pomocą pop możesz odzyskać wartość
powiedz,
x = l.pop(0)
x
że będzie0
źródło
Następnie po prostu usuń:
źródło
Możesz użyć
list.reverse()
do odwrócenia listy, a następnielist.pop()
do usunięcia ostatniego elementu, na przykład:źródło
Możesz także użyć
list.remove(a[0])
dopop
wyrzucenia pierwszego elementu z listy.źródło
a.remove(a[1-1])
? To inny sposób.list.remove(a[i])
. Przy zduplikowanych wartościach może znaleźć wcześniejszy element o tej samej wartości i usunąć go zamiast i-tego.Jeśli pracujesz z Numpy , musisz użyć metody usuwania :
źródło
Istnieje struktura danych o nazwie „deque” lub kolejka dwustronna, która jest szybsza i wydajniejsza niż lista. Możesz użyć swojej listy i przekonwertować ją na deque i dokonać w niej wymaganych przekształceń. Możesz także przekonwertować deque z powrotem na listę.
Deque zapewnia również bardzo przydatne funkcje, takie jak wstawianie elementów po obu stronach listy lub do dowolnego określonego indeksu. Możesz także obracać lub cofać deque. Spróbuj!!
źródło