Easy configuration of arguments in a python code!
Project description
Configer
This is the repository for the package CONFIGER helps with easy configuration of arguments in a python code.
Introduction
When Python programs grow large, one would eventually need a way to load configurations through a file. The common answer to this would by Python's ConfigParser. But at least I find the result of using ConfigParse an ugly code:
import ConfigParser
Config = ConfigParser.ConfigParser()
Config.read("c:\\tomorrow.ini")
Config.get(section, option)
That's why I packaged my solution to this issue. Configer basically gives you a flattened ConfigParser with extra functionality:
- dot-access of values in the settings file
- dump settings to a file for later use
- add different settings while choosing to overload previous one.
Dependencies
This package is written for Python 2.7.
The only dependency is configparser and will be installed automatically by the setup.py.
Installation
In the root directory, type in
pip install .
Examples
Overall Configer will be a sleek way to disentangle settings away from the mechanics. An exact copy of the above code will be:
from configer import Configer
Config = Configer(default_ps_fname='c:\\tomorrow.ini')
Config.option
Note that you don't have sections anymore and you can access an option with a dot-access approach.
Other use cases would be:
-
Loading default settings
default_ps_fname = 'pyconfiger/Configer/test/sample_settings.ini' ps = Configer(default_ps_fname=default_ps_fname) print(ps.status) # None -
Loading default settings while adding new arguments
ps = Configer(default_ps_fname=default_ps_fname, status=False) print(ps.status) # False ps.status = True print(ps.status) # True ps.new_status = True print(ps.new_status) # True -
Loading default settings while initializing with a dictionary of arguments
ps = Configer(default_ps_fname=default_ps_fname, status=False,**{'somethings': [1.0, 2.0]}) print(ps.somethings) # [1.0, 2.0] -
Adding and overloading with a second Configer instance
ps1 = Configer(status=False) ps2 = Configer(status=True, othersetting = 'this') ps3 = ps1 + ps2 print(ps3.status) # False print(ps3.othersetting) # 'this' ps4 = ps1.overload(ps2) print(ps4.status) # True -
Dumping current Configer instance as an .ini file
ps = Configer(default_ps_fname=default_ps_fname, status=False) print(ps.status) # False ps.dump_settings(fname='~/settings.ini') # saves the settings to the specified file
Tests
To run the tests, type in in the root directory:
python -m unittest discover
License
See LICENSE.txt
Author
Nima Ghorbani, nima.ghorbani@tuebingen.mpg.de
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
File details
Details for the file configer-1.2.tar.gz.
File metadata
- Download URL: configer-1.2.tar.gz
- Upload date:
- Size: 4.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.18.4 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/2.7.15rc1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
152561522e6116e000bb9d4badae958f1c95e21c652f7376db3d7319f02ec4fe
|
|
| MD5 |
5eee9edc0c965d553d9ebd22a0ea9314
|
|
| BLAKE2b-256 |
219bc64d4bfe9f6216ea48a7dd74476832633747dde05f59ee241e67e335e3f6
|