Skip to main content

Painless YAML configuration.

Project description

https://github.com/beetbox/confuse/workflows/Build/badge.svg?branch=master http://img.shields.io/pypi/v/confuse.svg

Confuse is a configuration library for Python that uses YAML. It takes care of defaults, overrides, type checking, command-line integration, environment variable support, human-readable errors, and standard OS-specific locations.

What It Does

Here’s what Confuse brings to the table:

  • An utterly sensible API resembling dictionary-and-list structures but providing transparent validation without lots of boilerplate code. Type config['num_goats'].get(int) to get the configured number of goats and ensure that it’s an integer.

  • Combine configuration data from multiple sources. Using layering, Confuse allows user-specific configuration to seamlessly override system-wide configuration, which in turn overrides built-in defaults. An in-package config_default.yaml can be used to provide bottom-layer defaults using the same syntax that users will see. A runtime overlay allows the program to programmatically override and add configuration values.

  • Look for configuration files in platform-specific paths. Like $XDG_CONFIG_HOME or ~/.config on Unix; “Application Support” on macOS; %APPDATA% on Windows. Your program gets its own directory, which you can use to store additional data. You can transparently create this directory on demand if, for example, you need to initialize the configuration file on first run. And an environment variable can be used to override the directory’s location.

  • Integration with command-line arguments via argparse or optparse from the standard library. Use argparse’s declarative API to allow command-line options to override configured defaults.

  • Include configuration values from environment variables. Values undergo automatic type conversion, and nested dicts and lists are supported.

Installation

Confuse is available on PyPI and can be installed using pip:

pip install confuse

Using Confuse

Confuse’s documentation describes its API in detail.

Credits

Confuse was made to power beets. Like beets, it is available under the MIT license.

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

confuse-2.0.0.tar.gz (50.8 kB view details)

Uploaded Source

Built Distribution

confuse-2.0.0-py3-none-any.whl (24.8 kB view details)

Uploaded Python 3

File details

Details for the file confuse-2.0.0.tar.gz.

File metadata

  • Download URL: confuse-2.0.0.tar.gz
  • Upload date:
  • Size: 50.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.27.1

File hashes

Hashes for confuse-2.0.0.tar.gz
Algorithm Hash digest
SHA256 acc57c45ec2a9850a90fe7c29812bbdd8405e48a49c1a22899df915d0aca941f
MD5 3a0c0253cb7b7bc797d634b4a6a7a1f3
BLAKE2b-256 40ef5d3427b61160325f6ba7928456a13f420d435559849e8a5ae0df0bc12585

See more details on using hashes here.

File details

Details for the file confuse-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: confuse-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 24.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.27.1

File hashes

Hashes for confuse-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3c6906a852926af89a0d83fa15a65b2859793ac4fcec61f31e2c1df59d2dead5
MD5 e9e90b58044a4e85217fec024055032c
BLAKE2b-256 77db3c0594c0341d1dd095d685c73f49507b2e5392c7588fd893d07a4c5d959f

See more details on using hashes here.

Supported by

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