https://github.com/rrwen/kwconfig
A Python module for managing config files in keyword style json format.
https://github.com/rrwen/kwconfig
config file json key keyvalue keyword manage module path value word
Last synced: about 1 year ago
JSON representation
A Python module for managing config files in keyword style json format.
- Host: GitHub
- URL: https://github.com/rrwen/kwconfig
- Owner: rrwen
- License: mit
- Created: 2017-05-22T09:32:04.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2017-08-16T17:36:55.000Z (over 8 years ago)
- Last Synced: 2025-03-11T00:08:28.979Z (about 1 year ago)
- Topics: config, file, json, key, keyvalue, keyword, manage, module, path, value, word
- Language: Python
- Homepage: https://rrwen.github.io/kwconfig
- Size: 238 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
README
kwconfig
========
| Richard Wen
| rrwen.dev@gmail.com
* `Documentation `_
* `PyPi Package `_
A Python module for managing config files in keyword style json format.
.. image:: https://badge.fury.io/py/kwconfig.svg
:target: https://badge.fury.io/py/kwconfig
.. image:: https://img.shields.io/github/issues/rrwen/kwconfig.svg
:target: https://github.com/rrwen/kwconfig/issues
.. image:: https://travis-ci.org/rrwen/kwconfig.svg?branch=master
:target: https://travis-ci.org/rrwen/kwconfig
.. image:: https://coveralls.io/repos/github/rrwen/kwconfig/badge.svg?branch=master
:target: https://coveralls.io/github/rrwen/kwconfig?branch=master
.. image:: https://img.shields.io/badge/license-MIT-blue.svg
:target: https://raw.githubusercontent.com/rrwen/kwconfig/master/LICENSE
.. image:: https://img.shields.io/github/forks/rrwen/kwconfig.svg
:target: https://github.com/rrwen/kwconfig/network
.. image:: https://img.shields.io/github/stars/rrwen/kwconfig.svg
:target: https://github.com/rrwen/kwconfig/stargazers
.. image:: https://img.shields.io/twitter/url/https/github.com/rrwen/kwconfig.svg?style=social
:target: https://twitter.com/intent/tweet?text=simple%20%23python%20%23package%20for%20keyword%20%23json%20%23configuration:%20https://github.com/rrwen/kwconfig
Install
-------
1. Install `Python `_
2. Install `kwconfig `_ via ``pip``
::
pip install kwconfig
For the latest developer version, see `Developer Install`_.
Usage
-----
.. code-block:: python
import kwconfig
# Specify a file path for creating kwconfig object
config = kwconfig.manage('config.json', defaults={'key0': 'value0'})
# Update the config file with a key and value dict
config.update({'key1': 'value1', 'key2': 'value2'})
# Add a keyword dict to existing config file
# If a key exists, it will be updated
# If a key does not exist, it will be added
other_config = {'key3': 'value3'}
other_config = config.add(other_config)
# Write new values using keyword dict
config.overwrite({
'new_key1': 'new_value1',
'new_key2': 'new_value2'
})
# Obtain a dict of the config file contents
kw = config.read()
# Remove the key named "key1"
config.remove('key1')
# Reset to defaults
config.reset()
# Parsing a keyword list into dict ----
# Create a sample list of keyword arguments
argv = ['--key1=value1', '--key2=value2']
# Parse into a keyword dict
kwdict = kwconfig.parse(argv)
# View the values of key1 and key2
print('key1: ' + kwdict['key1'])
print('key2: ' + kwdict['key2'])
For more usage details, see the `Documentation `_.
Developer Notes
---------------
Developer Install
*****************
Install the latest developer version with ``pip`` from github::
pip install git+https://github.com/rrwen/kwconfig
Install from ``git`` cloned source:
1. Ensure `git `_ is installed
2. Clone into current path
3. Install via ``pip``
::
git clone https://github.com/rrwen/kwconfig
cd kwconfig
pip install . -I
Tests
*****
1. Clone into current path ``git clone https://github.com/rrwen/kwconfig``
2. Enter into folder ``cd kwconfig``
3. Ensure `unittest `_ is available
4. Run tests
::
pip install . -I
python -m unittest
Documentation Maintenance
*************************
1. Ensure `sphinx `_ is installed ``pip install -U sphinx``
2. Update the documentation in ``docs/``
::
pip install . -I
sphinx-build -b html docs/source docs
Upload to Github
****************
1. Ensure `git `_ is installed
2. Add all files and commit changes
3. Push to github
::
git add .
git commit -a -m "Generic update"
git push
Upload to PyPi
**************
1. Ensure `twine `_ is installed ``pip install twine``
2. Ensure `sphinx `_ is installed ``pip install -U sphinx``
3. Run tests and check for OK status
4. Delete ``dist`` directory
5. Update the version in ``kwconfig/__init__.py``
6. Update the documentation in ``docs/``
7. Create source distribution
8. Upload to `PyPi `_
::
pip install . -I
python -m unittest
sphinx-build -b html docs/source docs
python setup.py sdist
twine upload dist/*