Skip to main content

The Strangely Familiar Config Parser

Project description

konfik-logo

>> The Strangely Familiar Config Parser <<

Codecov Code style: black MIT license

Konfik is a simple configuration parser that helps you access your config variables using dot (.) notation. This lets you to do this —

foo_bar_bazz = config.FOO.BAR.BAZZ

— instead of this —

foo_bar_bazz = config["FOO"]["BAR"]["BAZZ"]

Konfik currently supports TOML, YAML, DOTENV and JSON configuration formats.

⚙️ Installation

Install Konfik via pip:

pip install konfik

💡 Usage

Let's see how you can parse a TOML config file and access the configuration variables. For demonstration, we'll be using the following config.toml file:

# Contents of `config.toml`

title = "TOML Example"

[owner]
name = "Tom Preston-Werner"
dob = 1979-05-27T07:32:00-08:00 # First class dates

[servers]
  [servers.alpha]
  ip = "10.0.0.1"
  dc = "eqdc10"

  [servers.beta]
  ip = "10.0.0.2"
  dc = "eqdc10"

[clients]
data = [ ["gamma", "delta"], [1, 2] ]

Load the above config file and access the variables using dot notation:

from pathlib import Path
from konfik import Konfik

# Define the config path
BASE_DIR = Path(__file__).parent
CONFIG_PATH_TOML = BASE_DIR / "config.toml"

# Initialize the konfik class
konfik = Konfik(config_path=CONFIG_PATH_TOML)

# Print the config file as a Python dict
konfik.show_config()

# Get the config dict from the konfik class
config = konfik.config

# Access and print the variables
print(config.title)
print(config.owner)
print(config.owner.dob)
print(config.database.ports)
print(config.servers.alpha.ip)
print(config.clients)

The .show_config() method will print your entire config file as a colorized Python dictionary object like this:

{
    'title': 'TOML Example',
    'owner': {
        'name': 'Tom Preston-Werner',
        'dob': datetime.datetime(1979, 5, 27, 7, 32, tzinfo=<toml.tz.TomlTz object at
0x7f2dfca308b0>)
    },
    'database': {
        'server': '192.168.1.1',
        'ports': [8001, 8001, 8002],
        'connection_max': 5000,
        'enabled': True
    },
    'servers': {
        'alpha': {'ip': '10.0.0.1', 'dc': 'eqdc10'},
        'beta': {'ip': '10.0.0.2', 'dc': 'eqdc10'}
    },
    'clients': {'data': [['gamma', 'delta'], [1, 2]]}
}

Konfik also exposes a few command-line options for you to introspect your config file and variables. Run:

konfik --help

This will reveal the options associated with the CLI tool:

Konfik -- The strangely familiar config parser ⚙️

usage: konfik [-h] [--path PATH] [--show] [--show-literal] [--var VAR] [--version]

optional arguments:
  -h, --help      show this help message and exit
  --path PATH     add config file path
  --show          print config as a dict
  --show-literal  print config file content literally
  --var VAR       print config variable
  --version       print konfik-cli version number

To inspect the value of a specific variable in a ./config.toml file you can run:

konfik --path=config.toml --var=servers.alpha.ip
🍰

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

konfik-2.0.4.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

konfik-2.0.4-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file konfik-2.0.4.tar.gz.

File metadata

  • Download URL: konfik-2.0.4.tar.gz
  • Upload date:
  • Size: 7.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.1 Linux/5.8.0-7630-generic

File hashes

Hashes for konfik-2.0.4.tar.gz
Algorithm Hash digest
SHA256 84ce96e665d8360d05c448ec2981a8a0d5876d4d5c835545d3a828758b67201f
MD5 de2fe6d6226fe3fc1280989917b9ffc7
BLAKE2b-256 5661e29d40f305e880d6489439e34428f009df06ddd8df13310f013299221045

See more details on using hashes here.

File details

Details for the file konfik-2.0.4-py3-none-any.whl.

File metadata

  • Download URL: konfik-2.0.4-py3-none-any.whl
  • Upload date:
  • Size: 7.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.1 Linux/5.8.0-7630-generic

File hashes

Hashes for konfik-2.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a81cec8cc9fb1acc6824fc22d933b114297fb2260c3dcd293a58bef5f6c5325f
MD5 13fb0d57b46c7210394a11d8928e7424
BLAKE2b-256 836d86ced1d8af667ed53b985b5bb1df4c98589dea7cc4cf1ffc7e685dae5cea

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