En Python, ¿cómo obtienes el último elemento de una lista?
2067
some_list[-1]
Es el más corto y más pitónico.
De hecho, puede hacer mucho más con esta sintaxis. La some_list[-n]
sintaxis obtiene el enésimo elemento anterior. Entonces some_list[-1]
obtiene el último elemento, some_list[-2]
obtiene el penúltimo, etc., hasta el final some_list[-len(some_list)]
, lo que le da el primer elemento.
También puede establecer elementos de lista de esta manera. Por ejemplo:
>>> some_list = [1, 2, 3]
>>> some_list[-1] = 5 # Set the last element
>>> some_list[-2] = 3 # Set the second to last element
>>> some_list
[1, 3, 5]
Tenga en cuenta que obtener un elemento de la lista por índice aumentará IndexError
si el elemento esperado no existe. Esto significa que some_list[-1]
generará una excepción si some_list
está vacía, porque una lista vacía no puede tener un último elemento.
some_list.last
: sería una hermosa línea de códigoSi sus objetos
str()
olist()
pueden terminar vacíos de esta manera:astr = ''
oalist = []
, entonces es posible que desee usarlos enalist[-1:]
lugar de laalist[-1]
"igualdad" de los objetos.El significado de esto es:
Donde se hace la distinción es que devolver un objeto de lista vacío o un objeto str vacío es más "último elemento", como un objeto de excepción.
fuente
if len(my_vector) == 0 or my_vector[-1] != update_val
es un patrón viable. pero ciertamente no es una solución global: sería bueno tener una forma de sintaxis donde Ninguno fuera el resultadoxs[-1] if xs else None
También puedes hacer:
Depende de lo que quieras hacer con tu lista porque el
pop()
método eliminará el último elemento.fuente
La forma más sencilla de mostrar el último elemento en Python es
Hay muchos otros métodos para lograr ese objetivo, pero estos son cortos y dulces de usar.
fuente
list[-1]
que error.a[-1:][0]
en absoluto ? Él proporciona dea[-1]
todos modos también. ¿Explicación por favor?Para obtener el último elemento,
pasar
-1
a la notación de subíndice:Explicación
Los índices y sectores pueden tomar enteros negativos como argumentos.
He modificado un ejemplo de la documentación para indicar a qué elemento de una secuencia hace referencia cada índice, en este caso, en la cadena
"Python"
, hace-1
referencia al último elemento, el carácter'n'
,:Asignación mediante desembalaje iterable
Este método puede materializar innecesariamente una segunda lista con el fin de obtener el último elemento, pero en aras de la integridad (y dado que admite cualquier iterable, no solo listas):
El nombre de la variable, head está vinculado a la lista innecesaria recién creada:
Si tiene la intención de no hacer nada con esa lista, esto sería más apropiado:
O, realmente, si sabe que es una lista (o al menos acepta la notación de subíndice):
En una función
Un comentarista dijo:
Estos serían bastante simples de definir:
O use
operator.itemgetter
:En cualquier caso:
Casos especiales
Si está haciendo algo más complicado, es posible que le resulte más eficaz obtener el último elemento de formas ligeramente diferentes.
Si es nuevo en la programación, debe evitar esta sección, ya que combina partes semánticamente diferentes de algoritmos juntas. Si cambia su algoritmo en un lugar, puede tener un impacto no deseado en otra línea de código.
Trato de proporcionar advertencias y condiciones lo más completamente posible, pero es posible que me haya perdido algo. Comenta si crees que estoy dejando una advertencia.
Rebanar
Un segmento de una lista devuelve una nueva lista, por lo que podemos dividir desde -1 hasta el final si vamos a querer el elemento en una nueva lista:
Esto tiene la ventaja de no fallar si la lista está vacía:
Mientras que intentar acceder por índice genera un problema
IndexError
que debería ser manejado:Pero nuevamente, el corte para este propósito solo debe hacerse si necesita:
for
buclesComo característica de Python, no hay alcance interno en un
for
bucle.Si ya está realizando una iteración completa sobre la lista, el último elemento seguirá siendo referenciado por el nombre de variable asignado en el bucle:
Esto no es semánticamente lo último en la lista. Esto es semánticamente lo último a lo que
item
estaba obligado el nombre .Por lo tanto, esto solo debe usarse para obtener el último elemento si
Conseguirlo y eliminarlo
También podemos mutar nuestra lista original eliminando y devolviendo el último elemento:
Pero ahora se modifica la lista original.
(en
-1
realidad es el argumento predeterminado, por lo quelist.pop
puede usarse sin un argumento de índice):Solo haz esto si
Estos son casos de uso válidos, pero no muy comunes.
Guardar el resto del reverso para más tarde:
No sé por qué lo haría, pero para completar, ya que
reversed
devuelve un iterador (que admite el protocolo de iterador) puede pasar su resultado anext
:Entonces es como hacer lo contrario de esto:
Pero no puedo pensar en una buena razón para hacer esto, a menos que necesite el resto del iterador inverso más adelante, que probablemente se parecería más a esto:
y ahora:
fuente
Para evitarlo
IndexError: list index out of range
, use esta sintaxis:fuente
Otro método:
fuente
lst[-1]
es el mejor enfoque, pero con iterables generales, consideremore_itertools.last
:Código
fuente
list[-1]
recuperará el último elemento de la lista sin cambiar la lista.list.pop()
recuperará el último elemento de la lista, pero mutará / cambiará la lista original. Por lo general, no se recomienda mutar la lista original.Alternativamente, si, por alguna razón, está buscando algo menos pitónico, podría usarlo
list[len(list)-1]
, suponiendo que la lista no esté vacía.fuente
También puede usar el siguiente código, si no desea obtener IndexError cuando la lista está vacía.
fuente
Ok, pero ¿qué hay de común en casi todos los idiomas
items[len(items) - 1]
? Esta es la OMI la forma más fácil de obtener el último elemento, ya que no requiere ningún conocimiento pitónico .fuente
some_list[-1]
enfoque porque es más lógico y muestra lo que en realidad está haciendo mejor quesome_list[-1]
en mi opinión.