An open API service indexing awesome lists of open source software.

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.

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/*