У мене є список, в який [0, 1, 2, 3, 4]
я хотів би його скласти [1, 2, 3, 4]
. Як мені це зробити?
У мене є список, в який [0, 1, 2, 3, 4]
я хотів би його скласти [1, 2, 3, 4]
. Як мені це зробити?
Відповіді:
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'])
Нарізка:
x = [0,1,2,3,4]
x = x[1:]
Що б насправді повертало підмножину оригіналу, але не змінювало його.
x
він порожній, x=x[1:]
залишив би його порожнім, не нарікаючи. x.pop(0)
кине за порожній список x
. Іноді кидання - це те, що хочеться: Якщо припущення про наявність принаймні елемента в списку невірно, можна попросити отримати сповіщення.
>>> x = [0, 1, 2, 3, 4]
>>> x.pop(0)
0
Більше про це тут .
Ви можете скористатися 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
Ви можете також використовувати list.remove(a[0])
для pop
з першого елемента в списку.
>>>> a=[1,2,3,4,5]
>>>> a.remove(a[0])
>>>> print a
>>>> [2,3,4,5]
a.remove(a[1-1])
? Це ще один спосіб.
list.remove(a[i])
. При повторюваних значеннях він може знайти попередній елемент з тим же значенням і видалити цей замість i'th.
Існує структура даних під назвою "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 також пропонує дуже корисні функції, такі як вставлення елементів у будь-яку сторону списку або в будь-який конкретний індекс. Ви також можете обертати або повертати деке. Спробувати!!