19. Generadores I
Vídeo
Notas personales
Un generador es una estructura que extrae valores de una función y los almacena, de uno en uno, en objetos iterables (que se pueden recorrer). Cada vez que un generador almacena un valor, permanece en un estado pausado hasta que se solicita el siguiente, característica que se conoce como suspensión de estado.
La utilidad de los generadores reside en que:
- son más eficientes que las funciones tradicionales (sobretodo en consumo de recursos y tiempo, al no tener que construir ‘‘estructuras completas de datos’');
- resultan muy útiles con listas de valores infinitos; y
- bajo determinados escenarios, será recomendable que un generador devuelva los valores de uno en uno.
Su sintaxis es:
def nombre():
yield
Creemos un programa que nos genere una lista de números pares, primero a través de una función y luego utilizando generadores:
def genera_pares(limite):
num = 1
lista_pares = []
while num < limite:
lista_pares.append(num * 2)
num += 1
return lista_pares
print(genera_pares(10)) # [2, 4, 6, 8, 10, 12, 14, 16, 18]
def genera_pares(limite):
num = 1
while num < limite:
yield num * 2
num += 1
# Creo el objeto iterable que genera la función
devuelve_pares = genera_pares(10)
# Recorro el objeto iterable con, por ejemplo, un bucle for
for i in devuelve_pares:
print(i)
# 2
# 4
# 6
# 8
# 10
# 12
# 14
# 16
# 18
Imaginemos ahora que nuestro objetivo es imprimir en la consola únicamente los tres primeros números pares. Con el método next()
podemos solicitar valores de uno en uno al objeto iterable fruto del generador:
def genera_pares(limite):
num = 1
while num < limite:
yield num * 2
num += 1
# Creo el objeto iterable que genera la función
devuelve_pares = genera_pares(10)
print(next(devuelve_pares)) # 2
print("Aquí podría ir más código.")
print(next(devuelve_pares)) # 4
print("Aquí podría ir más código.")
print(next(devuelve_pares)) # 6
Código fuente
El código fuente y los posibles ficheros externos generados correspondientes a esta lección se encuentran disponibles para su consulta en la carpeta /lecciones/19/
del
repositorio.