Skip to main content

Import JSON/YAML/INI/XML like .py files

Project description

Build Status Supported Python versions PyPI version Coverage Status

ezcf stands for easy configuration, it allows you to import JSON/YAML/INI/XML like .py files. It is useful whenever you need to read from these formats, especially for reading configuration files.

OK, stop talking, show us some code!

On the left is what you’ll normally do, on the right is the ezcf way. Much more elegant isn’t it?

Install

pip install ezcf

If you run into error: yaml.h: No such file or directory, don’t worry, you can still use ezcf without any problem.

Supported File Types

ezcf supports JSON, YAML, INI and XML with extension json, yaml, yml, ini, xml.

Sample Usage

ezcf supports all kinds of valid import statements, here’s an example:

├── subdir
│   ├── __init__.py
│   └── sample_yaml.yaml
├── test_normal.py
└── sample_json.json

Various ways to use configurations in sample_yaml.yaml and sample_json.json:

import ezcf

from subdir.sample_yaml import *
# or
from subdir.sample_yaml import something
# or
import subdir.sample_yaml as sy
print(sy.something)

from sample_json import *
# or
from sample_json import something
# or
import sample_json as sj
print(sj.something)

You can assume they’re just regular python files.(Currently ezcf only supports files with utf-8 encoding)

What about relative import? Yes, ezcf supports relative import, as long as you use it correctly.

Something to note before using ezcf:

  1. ezcf is still in developement. If you find any bug, please report it in issues;

  2. Be careful importing YAML which contains multiple documents: if there exists keys with the same name, only one of them will be loaded. So it’s better not to use multiple documents;

  3. All values in .ini files are kept as it is and loaded as a string;

  4. Since XML only allows single root, the whole xml will be loaded as one dict with root’s name as variable name;

  5. Namespace package is not supported yet, pull requests are welcome.

Run Tests

python setup.py test

Roadmap

  • [x] Use dot to seperate folder/subfolder/file

  • [x] Unicode support

  • [x] JSON support

  • [x] YAML support

  • [x] INI support

  • [x] XML support

  • [ ] Auto encoding detect?

  • [x] CI

  • [x] coverage

  • [x] pypi

License

MIT

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

ezcf-0.2.0.tar.gz (7.4 kB view hashes)

Uploaded Source

Built Distribution

ezcf-0.2.0-py2.py3-none-any.whl (9.5 kB view hashes)

Uploaded Python 2 Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page