Skip to main content

Type-safe environment variable loading with casting and defaults.

Project description

philiprehberger-dotenv-cast

Tests PyPI version Last updated

Type-safe environment variable loading with casting and defaults.

Installation

pip install philiprehberger-dotenv-cast

Usage

from philiprehberger_dotenv_cast import env, load_dotenv

# Load a .env file into os.environ
load_dotenv()

# Read variables with type casting
host = env.str("HOST", "localhost")
port = env.int("PORT", 8080)
debug = env.bool("DEBUG", False)
tags = env.list("TAGS")  # "a,b,c" -> ["a", "b", "c"]

Boolean Casting

Boolean values are case-insensitive:

  • Truthy: "true", "1", "yes", "on"
  • Falsy: "false", "0", "no", "off"

List Splitting

# Default separator is ","
tags = env.list("TAGS")  # "a, b, c" -> ["a", "b", "c"]

# Custom separator
paths = env.list("PATHS", separator=":")

JSON Parsing

config = env.json("CONFIG")  # '{"key": "value"}' -> {"key": "value"}

Missing Variables

Variables without a default raise MissingEnvError:

from philiprehberger_dotenv_cast import env, MissingEnvError

try:
    secret = env.str("SECRET_KEY")  # raises if not set
except MissingEnvError:
    print("SECRET_KEY is required")

Loading .env Files

from philiprehberger_dotenv_cast import load_dotenv

# Load default .env
load_dotenv()

# Load a specific file
load_dotenv("config/.env.production")

API

Method / Function Description
env.str(key, default?) Get variable as string
env.int(key, default?) Get variable cast to int
env.float(key, default?) Get variable cast to float
env.bool(key, default?) Get variable cast to bool
env.list(key, separator?, default?) Get variable split into a list
env.json(key, default?) Get variable parsed as JSON
load_dotenv(path?) Load a .env file into os.environ
Env Class for creating custom instances
MissingEnvError Raised when a required variable is missing

Development

pip install -e .
python -m pytest tests/ -v

Support

If you find this project useful:

Star the repo

🐛 Report issues

💡 Suggest features

❤️ Sponsor development

🌐 All Open Source Projects

💻 GitHub Profile

🔗 LinkedIn Profile

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

philiprehberger_dotenv_cast-0.1.2.tar.gz (6.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

philiprehberger_dotenv_cast-0.1.2-py3-none-any.whl (5.3 kB view details)

Uploaded Python 3

File details

Details for the file philiprehberger_dotenv_cast-0.1.2.tar.gz.

File metadata

File hashes

Hashes for philiprehberger_dotenv_cast-0.1.2.tar.gz
Algorithm Hash digest
SHA256 cf9577d62692533f3e65234a3e9c6a28ad8ba3ed074453315e3dfb792beb2f17
MD5 89d2175eeeebfd7aea229f5062cf81e3
BLAKE2b-256 3f2ef61692f86cfdb9ef6266d460cd55879eac20e8484ca865e996ab9e2e7aa5

See more details on using hashes here.

File details

Details for the file philiprehberger_dotenv_cast-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for philiprehberger_dotenv_cast-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e2c55d8404eb2bb883e68d9dc5f3fe38da3ac565adc0a0c48de27b686664e212
MD5 2b3dd3ed70020319a0ca92841f02e247
BLAKE2b-256 992ff1f16c8644141ea93a15f86a76f74637440c34bde2e960708d38e9fcd982

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page