Skip to main content

painless YAML configuration

Project description

Confuse: painless YAML config files that Just Work
==================================================

.. image:: https://travis-ci.org/sampsyo/confuse.svg?branch=master
:target: https://travis-ci.org/sampsyo/confuse

.. image:: http://img.shields.io/pypi/v/confuse.svg
:target: https://pypi-hypernode.com/pypi/confuse


I'm tired of fiddling around with `ConfigParser`_. I don’t even really
like INI syntax. I'm tired of writing boilerplate code to check for
missing values, fall back to defaults, override config values with
command-line options, and all that. I think a configuration library
should be able to handle a lot more for me.

So I'm writing **Confuse** to magically take care of defaults, overrides,
type checking, command-line integration, human-readable errors, and
standard OS-specific locations. The configuration files will be based on
`YAML`_, which is a great syntax for writing down data.

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
Mac OS X; ``%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.

Using Confuse
------------

`Confuse’s documentation`_ describes its API in detail.

Author
------

Confuse is being developed by `Adrian Sampson`_. It’s not done yet, but
you’re welcome to use it under the terms of the `MIT license`_. Confuse was
originally made to power `beets`_.

.. _ConfigParser: http://docs.python.org/library/configparser.html
.. _YAML: http://yaml.org/
.. _optparse: http://docs.python.org/dev/library/optparse.html
.. _argparse: http://docs.python.org/dev/library/argparse.html
.. _logging: http://docs.python.org/library/logging.html
.. _Confuse’s documentation: http://confuse.readthedocs.org/
.. _Adrian Sampson: https://github.com/sampsyo
.. _MIT license: http://www.opensource.org/licenses/mit-license.php
.. _beets: https://github.com/beetbox/beets

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-0.5.0.tar.gz (32.7 kB view details)

Uploaded Source

File details

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

File metadata

  • Download URL: confuse-0.5.0.tar.gz
  • Upload date:
  • Size: 32.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for confuse-0.5.0.tar.gz
Algorithm Hash digest
SHA256 b8f5a73ec9d385fda8f91949a426e2d5fc4f2cb6d407272376d6ec340e159c0f
MD5 f51555e2aecfef2b147bcedaeee0fd7d
BLAKE2b-256 413930857a64e9530ba184c6546b3bd7e10e6ede91fad70bc2302a21de0a3648

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