The Strangely Familiar Config Parser
Project description
>> The Strangely Familiar Config Parser <<
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
🎉 Contribution
-
Clone the repo.
-
Spin up and activate your virtual environment. You can use anything between Python 3.6 to Python 3.9.
-
Install poetry.
-
Install the dependencies via:
poetry install
-
Make your changes to the
konfik/__init__.py
file. -
Run the tests via the following command. Make sure you've Python 3.6 - Python 3.9 installed on your system, otherwise Tox would throw an error.
make test
-
Write a simple unit test for your change.
-
Run the linter via:
make lint
-
Send a pull request against the master branch.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file konfik-2.0.2.tar.gz
.
File metadata
- Download URL: konfik-2.0.2.tar.gz
- Upload date:
- Size: 7.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.4 CPython/3.9.0+ Linux/5.8.0-7625-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ced51afc7da47b5bca768f4c5e35338d8ed7d07b60c3b01ad2d5c8198d6134ec |
|
MD5 | 4b0b621bfa9016e590cbf2ab40b0aed0 |
|
BLAKE2b-256 | 7c991c97c05a36493808dcbba42c655d57945a4aca7fbe603ca2bfa385730b06 |
File details
Details for the file konfik-2.0.2-py3-none-any.whl
.
File metadata
- Download URL: konfik-2.0.2-py3-none-any.whl
- Upload date:
- Size: 7.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.4 CPython/3.9.0+ Linux/5.8.0-7625-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b60c36abfffb6e17433ac7aa4a90905b74aa34bd632d8d12d85825f5c37fc027 |
|
MD5 | 8574bd7dbc41fb580838d5b136ea2160 |
|
BLAKE2b-256 | 5494caac205ec8b19718c0c1605d485ddfdaab56845b470113b41cf5537957cd |