Tengo la lista [0, 1, 2, 3, 4]
que me gustaría incluirla [1, 2, 3, 4]
. ¿Cómo hago esto?
Tengo la lista [0, 1, 2, 3, 4]
que me gustaría incluirla [1, 2, 3, 4]
. ¿Cómo hago esto?
Respuestas:
list.pop (index)
>>> l = ['a', 'b', 'c', 'd']
>>> l.pop(0)
'a'
>>> l
['b', 'c', 'd']
>>>
del list [índice]
>>> l = ['a', 'b', 'c', 'd']
>>> del l[0]
>>> l
['b', 'c', 'd']
>>>
Ambos modifican su lista original.
Otros han sugerido usar rebanadas:
Además, si está ejecutando muchos pop (0), debería mirar collections.deque
from collections import deque
>>> l = deque(['a', 'b', 'c', 'd'])
>>> l.popleft()
'a'
>>> l
deque(['b', 'c', 'd'])
Rebanar:
x = [0,1,2,3,4]
x = x[1:]
Lo que en realidad devolvería un subconjunto del original pero no lo modificaría.
x
está vacío, x=x[1:]
lo dejaría vacío sin quejarse. x.pop(0)
tiraría por una lista vacía x
. A veces, lanzar es lo que uno quiere: si la suposición de que hay al menos un elemento en la lista es incorrecta, es posible que desee recibir una notificación.
>>> x = [0, 1, 2, 3, 4]
>>> x.pop(0)
0
Más sobre esto aquí .
Puede usar list.reverse()
para invertir la lista y luego list.pop()
eliminar el último elemento, por ejemplo:
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
También puede usar list.remove(a[0])
para pop
eliminar el primer elemento de la lista.
>>>> a=[1,2,3,4,5]
>>>> a.remove(a[0])
>>>> print a
>>>> [2,3,4,5]
a.remove(a[1-1])
? Esa es otra forma.
list.remove(a[i])
. Con valores duplicados, puede encontrar un elemento anterior con el mismo valor y eliminar ese en lugar del i.
Si está trabajando con numpy , debe usar el método de eliminación :
import numpy as np
a = np.array([1, 2, 3, 4, 5])
a = np.delete(a, 0)
print(a) # [2 3 4 5]
Hay una estructura de datos llamada "deque" o cola doble que es más rápida y eficiente que una lista. Puede usar su lista y convertirla a deque y hacer las transformaciones requeridas en ella. También puede convertir la deque a la lista.
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 también proporciona funciones muy útiles, como insertar elementos en cualquier lado de la lista o en cualquier índice específico. También puede rotar o invertir una deque. ¡¡Darle una oportunidad!!