@DaniSpringer Porque no está asignando a una lista. Es lo mismo que hacer lst = [1, 2, 3]; e = lst[0]; e += 1. eno tiene ninguna información sobre de dónde vino, es solo una variable a la que se ha asignado un elemento de una lista. Después de asignarle algo más, la lista lstno cambiará.
Błażej Michalik
Bueno, esta respuesta me parece muy similar.
Daniel Springer el
y el corresponsal perezoso calculó uno:new_list = (x+1 for x in my_list)
Eduardo Pignatelli
26
>>> mylist =[1,2,3]>>>[x+1for x in mylist][2,3,4]>>>
Las otras respuestas en la comprensión de la lista son probablemente la mejor opción para la suma simple, pero si tiene una función más compleja que necesitaba aplicar a todos los elementos, entonces el mapa puede ser una buena opción.
Esto es bueno para cambiar la lista existente, pero aún produce una nueva. ¿De alguna manera no es seguro usar un generador para evitar la creación innecesaria de listas? Es decir, _list[:]=(i+1 for i in _list).
Alan
eso todavía crea una nueva lista, no es posible hacerlo en el lugar sin un bucle for, no creo
robert king
¿Por qué crees que _list[:]=(i+1 for i in _list)crea una nueva lista?
Veo a que te refieres. Llamar a la secuencia temporal una lista me confundió. ¿Sabemos realmente algo sobre su tipo? ¿No sería eso una implementación específica?
Alan
9
>>>[x.__add__(1)for x in[1,3,5]]3:[2,4,6]
Mi intención aquí es exponer si el elemento en la lista es un entero que admite varias funciones integradas.
Muchas de las respuestas anteriores son muy buenas. También he visto algunas respuestas extrañas que harán el trabajo. Además, la última respuesta vista fue a través de un bucle normal. Esta disposición a dar respuestas me lleva a itertoolsy numpy, que hará el mismo trabajo de una manera diferente.
Aquí presento diferentes formas de hacer el trabajo, no respondidas anteriormente.
import operator
import itertools
x =[3,5,6,7]
integer =89"""
Want more vairaint can also use zip_longest from itertools instead just zip
"""#lazy eval
a = itertools.starmap(operator.add, zip(x,[89]* len(x)))# this is not subscriptable but iterableprint(a)for i in a:print(i, end =",")# prepared list
a = list(itertools.starmap(operator.add, zip(x,[89]* len(x))))# this returns listprint(a)# With numpy (before this, install numpy if not present with `pip install numpy`)import numpy
res = numpy.ones(len(x), dtype=int)* integer + x # it returns numpy array
res = numpy.array(x)+ integer # you can also use this, infact there are many ways to play aroundprint(res)print(res.shape)# prints structure of array, i.e. shape# if you specifically want a list, then use tolist
res_list = res.tolist()print(res_list)
Salida
>>><itertools.starmap object at 0x0000028793490AF0># output by lazy val>>>92,94,95,96,# output of iterating above starmap object>>>[92,94,95,96]# output obtained by casting to list>>> __
>>># |\ | | | |\/| |__| \ />>># | \| |__| | | | |>>>[92949596]# this is numpy.ndarray object>>>(4,)# shape of array>>>[92,94,95,96]# this is a list object (doesn't have a shape)
Mi única razón para resaltar el uso de numpyes que uno siempre debe hacer tales manipulaciones con bibliotecas como numpy porque es eficiente en el rendimiento para matrices muy grandes.
lst = [1, 2, 3]; e = lst[0]; e += 1
.e
no tiene ninguna información sobre de dónde vino, es solo una variable a la que se ha asignado un elemento de una lista. Después de asignarle algo más, la listalst
no cambiará.new_list = (x+1 for x in my_list)
lista-comprensiones de python .
fuente
Las otras respuestas en la comprensión de la lista son probablemente la mejor opción para la suma simple, pero si tiene una función más compleja que necesitaba aplicar a todos los elementos, entonces el mapa puede ser una buena opción.
En su ejemplo sería:
fuente
map(1 .__add__, ...)
también funciona Tenga en cuenta que necesita un espacio entre1
y.
para evitar que el analizador piense que es un flotadorsi quieres usar numpy hay otro método de la siguiente manera
fuente
Editar: esto no está en su lugar
En primer lugar, no use la palabra 'lista' para su variable. Sombra la palabra clave
list
.La mejor manera es hacerlo en el lugar mediante empalme, tenga en cuenta que
[:]
denota un empalme:fuente
_list[:]=(i+1 for i in _list)
._list[:]=(i+1 for i in _list)
crea una nueva lista?Mi intención aquí es exponer si el elemento en la lista es un entero que admite varias funciones integradas.
fuente
Python 2+:
Python 3+:
fuente
lo que da
fuente
Encontré una forma no tan eficiente, pero única de hacerlo. Por lo tanto, compartirlo. Y sí, requiere espacio adicional para otra lista.
fuente
from operator import add
fuente
Muchas de las respuestas anteriores son muy buenas. También he visto algunas respuestas extrañas que harán el trabajo. Además, la última respuesta vista fue a través de un bucle normal. Esta disposición a dar respuestas me lleva a
itertools
ynumpy
, que hará el mismo trabajo de una manera diferente.Aquí presento diferentes formas de hacer el trabajo, no respondidas anteriormente.
Salida
Mi única razón para resaltar el uso de
numpy
es que uno siempre debe hacer tales manipulaciones con bibliotecas como numpy porque es eficiente en el rendimiento para matrices muy grandes.fuente