merge multi level configurations
Project description
configmerger
merge multi level configurations.
Usage
from configmerger import Merger
# your configurations, read from app.json, machine.yaml, user.toml, or more
confs = [
read_from_app(),
read_from_machine(),
read_from_user(),
]
# merge all configurations into one.
runtime_conf = Merger().merge(confs)
Merge Rules
Here is the default merge rules:
merger = Merger()
# for dict, a little like Chainmap
merger.merge([
{'a': 1},
{'a': 2, 'b': 3},
{ 'b': 4}
])
# {'a': 2, 'b': 4}
# for list, default behavior is connect each
# change `merger.connect_list` to `False` can change this behavior
merger.merge([ [1, 2, 3], [4, 5] ]) # [4, 5, 1, 2, 3]
# for str, int and others, latest have highest priority
merger.merge([ 'first', 'last' ]) # 'last'
# basic, `None` is ignored
merger.merge([ 1, None ]) # 1
# but if all values is `None`, return `None`
merger.merge([ None, None ]) # None
# if type changed, merge will stop,
merger.merge([
{'a': 1}, # <--- ignored
1, # <--- type changed, ignore all before this
{'b': 2},
None, # <--- None is ignored
{'c': 3},
])# {'b': 2, 'c': 3}
Override any methods to modify the default behavior.
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
configmerger-0.1.0.tar.gz
(3.2 kB
view hashes)
Built Distribution
Close
Hashes for configmerger-0.1.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1853098414e0da9f0381c7738b482f48092fb7e739086ac5746fbadd9553fd09 |
|
MD5 | d6b56b1de6111d42624264490feeeb2c |
|
BLAKE2b-256 | 375f8da4120d28869f6f34260a9e070d8af55fc276bbeee71e9476aed2764dae |