Ir al contenido principal

Optimiza tu Código en Python con functools.lru_cache

 


El mundo de la programación está lleno de trucos y herramientas que pueden ayudarte a optimizar tu código y mejorar su rendimiento. Uno de estos trucos menos conocidos pero extremadamente útiles en Python es el uso del decorador functools.lru_cache. En este artículo, exploraremos cómo usar lru_cache para optimizar funciones costosas y repetitivas, y cómo puede beneficiar tu proyecto.

¿Qué es functools.lru_cache?

functools.lru_cache es un decorador en Python que almacena en caché (cache) los resultados de las llamadas a funciones. Esto significa que cuando una función decorada con lru_cache se llama con los mismos argumentos, el resultado se recupera de la caché en lugar de calcularse nuevamente. Esto puede ahorrar mucho tiempo, especialmente en funciones que realizan cálculos intensivos o consultas repetitivas.

Beneficios de Usar lru_cache

  1. Optimización de Rendimiento: Mejora significativamente el rendimiento de funciones recursivas o funciones que se llaman repetidamente con los mismos argumentos.
  2. Simplicidad: Fácil de implementar con cambios mínimos en el código existente.
  3. Configurabilidad: Puedes ajustar el tamaño de la caché con el parámetro maxsize. Si se establece en None, la caché puede crecer indefinidamente.

Ejemplo Práctico: Cálculo de Fibonacci

Calcular números de Fibonacci recursivamente es un buen ejemplo para demostrar el poder de lru_cache. Sin optimización, este cálculo puede ser extremadamente ineficiente.

python
from functools import lru_cache @lru_cache(maxsize=None) def fibonacci(n): if n < 2: return n return fibonacci(n - 1) + fibonacci(n - 2) # Llamadas a la función print(fibonacci(10)) # Salida: 55 print(fibonacci(20)) # Salida: 6765 print(fibonacci(30)) # Salida: 832040

En este ejemplo, la función fibonacci se optimiza utilizando lru_cache, almacenando en caché los resultados de llamadas previas y evitando cálculos redundantes.

Uso en Consultas Frecuentes

Otro uso práctico de lru_cache es en funciones que realizan consultas a bases de datos. Imagina una función que ejecuta una consulta costosa cada vez que se llama.

python
import time from functools import lru_cache @lru_cache(maxsize=32) def consulta_bd(query): print(f"Ejecutando consulta para: {query}") time.sleep(2) # Simula una consulta costosa return f"Resultado para {query}" # Llamadas a la función print(consulta_bd("SELECT * FROM usuarios")) # Ejecuta la consulta print(consulta_bd("SELECT * FROM usuarios")) # Utiliza el caché print(consulta_bd("SELECT * FROM productos")) # Ejecuta la consulta

En este ejemplo, la primera vez que se llama a consulta_bd("SELECT * FROM usuarios"), la consulta se ejecuta y se almacena en caché. Las llamadas subsiguientes con el mismo argumento recuperan el resultado de la caché, ahorrando tiempo.

Implementación y Buenas Prácticas

  • Parámetro maxsize: Define el tamaño máximo de la caché. Un valor más alto permite almacenar más resultados, pero consume más memoria.
  • Control de Caché: Asegúrate de que las funciones caché no almacenen datos sensibles o cambiantes frecuentemente.
  • Monitorización: Utiliza herramientas de monitoreo para observar el rendimiento y ajuste el tamaño de la caché según sea necesario.

Conclusión

functools.lru_cache es una herramienta poderosa para mejorar el rendimiento de tu código en Python. Ya sea para optimizar funciones recursivas como el cálculo de Fibonacci o para acelerar consultas frecuentes a bases de datos, lru_cache puede ahorrar tiempo y recursos significativamente.

Para más detalles sobre functools.lru_cache, puedes consultar la documentación oficial de Python.

Comentarios

Entradas populares de este blog

Lenguajes de programación más conocidos en la historia de la computación

Los primeros lenguajes de programación eran difíciles de construir ya que éstos debían ser "desarrollados" a un nivel que la máquina entendiera directamente, es decir, la programación de computadoras de esta época dependía mucho de la máquina para la que se estaba trabajando y detectar un error o fallo en la programación no solo era complejo sino que demandaba mucho tiempo y esfuerzo. En 1946 Grace Murray Hopper, científica en sistemas y oficial de la marina estadounidense creo el FLOW-MATIC, considerado el primer lenguaje de programación útil para resolver problemas de usuarios comerciales.  Su desarrollo fue enfocado a la UNIVAC 1.  Este lenguaje de programación fue visto como de "alto nivel", fácil de usar por los científicos de la época.  FLOW-MATIC requería de un traductor (compilador) para ser interpretado por la máquina.   Con este lenguaje de programación se establece el concepto de programación basado en palabras del lenguaje natural y se da inicio al d

Enviar archivos por sftp con Python

Esta es una breve modificación a uno de los scripts creados con anterioridad y que consiste en enviar un archivo por  sftp.   La necesidad en concreto consistía en comparar ambos servidores local y remoto y validar qué archivo faltaba en el remoto que estuviera en el local para proceder a enviarlo y mantener el remoto actualizado. Este script se guarda con el nombre que quieras, le das permiso de ejecución y lo agregas en un crontab. import pysftp import os # Cambiar por la ruta donde se generan los archivos (Amsterdam) servidor_local = os.listdir(r'C:\proyecto\archivos') #print servidor_local # Cambiar por una ruta en Amsterdam, puede ser /tmp/res os.remove(r"c:\proyecto\res\archivos.txt") for archivos in servidor_local: # Cambiar por '/tmp/res/archivos.txt','a' local = open(r"c:\proyecto\res\archivos.txt",'a') print 'Archivo local: '+archivos local.write(str(archivos)+'\n')

Extraer logs de un rango de hora

Seguramente en sus trabajos se habrán visto en la necesidad de extraer logs en un rango dado de hora; es decir, desde las xx hasta las yy. Este proceso se puede hacer en linux utilizando varios comando como el grep, head, cut, etc. que combinados nos mostrarán lo que andamos buscando. Como en mi trabajo actual es bastante común esta actividad me he dado a la tarea de crear un script bash para ello. Este es el código fuente que obviamente pueden mejor y/o adaptar a sus necesidades: #!/bin/bash ## Rango v.1.0 ## Genera un log con un rango de hora ingresado ## Autor: Manuel Gonzalez ## http://maengora.blogspot.com # Forma de usar el script echo "Con bash: ./rango.sh " # Solicito la hora inicial y la almaceno en la variable HORA_INICIAL echo -n "Hora incial hh:mm " read HORA_INICIAL # Solicito hora final echo -n "Hora final hh:mm " read HORA_FINAL # Solicito el nombre del log de donde voy a extraer la informacion echo -n "Nombre del log a analizar &qu