Skip to content

Latest commit

 

History

History
146 lines (95 loc) · 6.38 KB

File metadata and controls

146 lines (95 loc) · 6.38 KB

Capítulo 22: Leer archivos .env

Leer archivos .env en Python es una práctica común para manejar configuraciones sensibles o específicas del entorno sin hardcodearlas en el código fuente. Estos archivos suelen almacenar pares clave-valor que configuran variables de entorno necesarias para el funcionamiento de una aplicación. Aquí te explico cómo puedes leer estos archivos de manera efectiva.

¿Qué es un archivo .env?

Un archivo .env (environment) contiene configuraciones en formato de texto simple que asignan valores a variables de entorno. Por ejemplo, un archivo .env podría verse así:

DB_HOST=localhost
DB_USER=root
DB_PASS=12345
API_KEY=abcd1234

Usando la biblioteca python-dotenv

Para leer archivos .env en Python, la biblioteca python-dotenv es ampliamente utilizada porque facilita la carga de estas variables de entorno directamente en el entorno de Python. Primero, necesitas instalar la biblioteca si aún no lo has hecho:

pip install python-dotenv

Ejemplo Detallado de Cómo Leer un Archivo .env

  1. Creación de un archivo .env: Supongamos que tienes un archivo .env en el directorio raíz de tu proyecto con el contenido mencionado anteriormente.

  2. Cargar el archivo .env usando python-dotenv: Puedes cargar el archivo y usar las variables de entorno en tu código de la siguiente manera:

    from dotenv import load_dotenv
    import os
    
    # Cargar las variables de entorno del archivo .env
    load_dotenv()
    
    # Acceder a las variables de entorno
    db_host = os.getenv('DB_HOST')
    db_user = os.getenv('DB_USER')
    db_pass = os.getenv('DB_PASS')
    api_key = os.getenv('API_KEY')
    
    # Imprimir los valores para verificar que todo está cargado correctamente
    print("Database Host:", db_host)
    print("Database User:", db_user)
    print("Database Password:", db_pass)
    print("API Key:", api_key)

    En este código:

    • load_dotenv(): Esta función busca un archivo .env en el directorio actual y carga las variables de entorno encontradas. Si necesitas especificar una ruta diferente, puedes pasarla como argumento.
    • os.getenv(): Esta función de la biblioteca estándar os se utiliza para obtener el valor de una variable de entorno. Retorna None si la variable no está definida, lo que te permite manejar casos donde no todas las variables estén configuradas.

Función load_dotenv

La función load_dotenv de la biblioteca python-dotenv es una herramienta poderosa para gestionar configuraciones de entorno en aplicaciones Python, especialmente útil para separar la configuración del código y mejorar la seguridad. Aquí te explico cómo usar esta función con diferentes argumentos para ajustar su comportamiento según tus necesidades.

Definición Básica: load_dotenv carga variables de entorno desde un archivo .env en el entorno de Python, lo que permite acceder a ellas a través del módulo os con os.getenv.

Sintaxis Básica:

load_dotenv(dotenv_path=None, stream=None, verbose=False, override=False, interpolate=True)

Argumentos de load_dotenv

  • dotenv_path (str o PathLike, opcional): Ruta al archivo .env. Por defecto, busca un archivo .env en el directorio actual o en uno de sus directorios padres.

  • stream (IO, opcional): En lugar de leer desde un archivo, puede cargar las variables de entorno de un stream. Esto es útil para leer de objetos similares a archivos en lugar de archivos reales en el sistema.

  • verbose (bool, opcional): Si se establece en True, imprime mensajes que pueden ayudar a depurar problemas al cargar el archivo.

  • override (bool, opcional): Si es True, sobrescribe las variables de entorno existentes con los valores del archivo .env. Por defecto, es False, lo que significa que los valores existentes en las variables de entorno no se modificarán si ya están definidos.

  • interpolate (bool, opcional): Si es True, permite la interpolación de variables dentro del archivo .env (por ejemplo, PATH=$HOME/bin:$PATH). Por defecto, es True.

Ejemplos Detallados

  1. Cargar un archivo .env específico:

    Si tienes múltiples archivos .env, por ejemplo, uno para desarrollo y otro para producción, puedes especificar cuál cargar:

    from dotenv import load_dotenv
    import os
    
    # Cargar un archivo .env específico
    load_dotenv(dotenv_path='config/.env.development')
    
    # Obtener una variable de entorno
    db_host = os.getenv('DB_HOST')
    print("Database Host:", db_host)
  2. Uso de verbose para depuración:

    Si no estás seguro de si tus variables se están cargando correctamente, puedes usar el argumento verbose:

    load_dotenv(verbose=True)

    Esto imprimirá mensajes de ayuda que te indicarán si el archivo .env se ha cargado correctamente o si hubo errores en el camino.

  3. Sobrescribir variables de entorno existentes:

    Si necesitas que los valores de tu archivo .env tengan prioridad sobre las variables de entorno definidas en el sistema, usa override=True:

    load_dotenv(override=True)
  4. Cargar variables de entorno desde un stream:

    En situaciones donde el archivo .env no está directamente accesible como un archivo regular (por ejemplo, cuando se obtiene de un recurso en línea o de una base de datos), puedes cargarlo desde un stream:

    import io
    
    # Simulando un objeto de archivo con io.StringIO
    dotenv_content = io.StringIO("API_KEY=XYZ123")
    load_dotenv(stream=dotenv_content)
    
    api_key = os.getenv('API_KEY')
    print("API Key from stream:", api_key)

Ventajas del Uso de .env en Proyectos Python

  • Seguridad: Mantener las credenciales y claves secretas fuera del código fuente.
  • Flexibilidad: Fácil de cambiar la configuración sin necesidad de modificar el código.
  • Portabilidad: Facilita la configuración de diferentes entornos (desarrollo, prueba, producción) sin cambios en el código.

Este enfoque te permitirá manejar la configuración de tu aplicación de manera segura y eficiente, adaptándose fácilmente a diferentes entornos de desarrollo y producción.


Made with Love ❤️ by @jelambrar96

"Buy Me A Coffee"

Mayo 2024