Skip to main content

Configure components/classes using config files, command line options etc in a simple way

Project description

configsimple

Configure a command/tall and its components via command line options, config files and environment variables.

This builds on the ConfigArgParse package, but instead of a replacement for the ArgumentParser class, provides its own class ConfigSimple which can be used to define the possible settings using add_argument and after parsing the settings, to retrieve the setting values.

Each ConfigSimple instance represents either the "top level" settings (similar to ArgumentParser usually for tools and programs) or a component setting that belongs to a top level setting instance.

The configsimple package provides a default top level settings singleton, configsimple.config.

Here is an example of how to define the settings for the toplevel and two components, where the toplevel selects the component to get used:

example1.py:

from configsimple import config, ConfigSimple


class Component1:
    def __init__(self):
        myconf = ConfigSimple(component="comp1")
        config.add_config(myconf)  # always immediately add to top config!
        myconf.add_argument("--foo", default="22", type=int, help="The FOO setting!")
        myconf.parse_args()
        foo = myconf.get("foo")


class Component2:
    def __init__(self):
        myconf = ConfigSimple(component="comp2")
        config.add_config(myconf)
        myconf.add_argument("--foo", default="xyz", type=str, help="The FOO setting, but a different one!")
        myconf.parse_args()
        foo = myconf.get("foo")


if __name__ == "__main__":
    config.add_argument("--bar", help="The BAR setting")
    config.add_argument("--foo", help="The toplevel FOO setting")
    config.add_argument("--comp", type=int, choices=[1, 2], required=True,  help="Component number")
    config.parse_args()
    print("Toplevel foo is {}".format(config.get("foo")))
    compclass = [Component1, Component2][config.get("comp")-1]
    comp = compclass()
    print("Get the global comp1.foo: {}".format(config.get("comp1.foo")))
    print("Get the global comp2.foo: {}".format(config.get("comp2.foo")))

NOTE

This package is meant to build on and depend on ConfigArgParse package, but because of a problem in that code, a slightly modified version of configargparse.py is currently directly included.

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

configsimple-0.1.tar.gz (16.9 kB view hashes)

Uploaded Source

Built Distribution

configsimple-0.1-py3-none-any.whl (17.6 kB view hashes)

Uploaded Python 3

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