Skip to main content

Project created to given the possibility of create dynamics Json config files

Project description

python-json-config-parser

This project was created to give you the possibility of creating json config files dynamicaly using OOP

HOW TO INSTALL

Use pip to install it.

pip install python-json-config-parser

HOW TO USE

The Class Config takes two arguments, the first is a Schema(https://github.com/keleshev/schema) to ensure the model of config, the second is the str path of json config file.

If you don't specify the path, the default value('config.json') will be used if one exists in the same dir where the script is running.

For example:

The model file.

from schema import Use, And

SCHEMA_CONFIG = {
    "core":{
        "logging":{
            "format": And(Use(str), lambda string: len(string) > 0),
            "datefmt": And(Use(str), lambda string: len(string) > 0)
        },
        "allowed_clients":[
            {
                "ip":str, # <- Here you can use regex to validate the ip format
                "timeout":int
            }
        ]
    }
}

The config.json file

{
    "core":{
        "logging":{
            "format":"[%(asctime)s][%(levelname)s]: %(message)s",
            "datefmt": "%d-%b-%y %H:%M:%S"
        },
        "allowed_clients":[
            {
                "ip":"192.168.0.10",
                "timeout":60
            },
            {
                "ip":"192.168.0.11",
                "timeout":100
            }
        ]
    }
}

The istance of Config Class:

from jsonconfigparser import Config, ConfigException
import logging

try:
    config = Config(SCHEMA_CONFIG) # <- Here I'm using that SCHEMA_CONFIG we had declared, and the dir file default value is being used
except ConfigException as e:
    print(e)
    exit()

#to access your config you need just:


fmt = config.core.logging.format #look this, at this point I'm already using the config variable
dtfmt = config.core.logging.datefmt #here again

logging.getLogger(__name__)

logging.basicConfig(
    format=fmt,
    datefmt=dtfmt
    level=20
)

#the list of object example:

for client in config.core.allowed_clients:
    print(client.ip)
    print(client.timeout)

Instanced the first obj, you can instance Config in other files of your project just calling the Config without args like that:

from jsonconfigparser import Config, ConfigException

config = Config() #At this point you already have the configuration properties in your config object

CONTRIBUTE

Fork https://github.com/BrunoSilvaAndrade/python-json-config-parser/ , create commit and pull request to develop.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

File details

Details for the file python_json_config_parser-1.0.9-py3-none-any.whl.

File metadata

  • Download URL: python_json_config_parser-1.0.9-py3-none-any.whl
  • Upload date:
  • Size: 4.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.8.3 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.54.0 CPython/3.6.9

File hashes

Hashes for python_json_config_parser-1.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 f25536a377fb6aa9b0dfb849aa477db7f302d3dcdaf4d1dd802f7a2a5c272248
MD5 3865293fc55e93470babac2ebf6a267c
BLAKE2b-256 d63a7c79fb91c6ed31fd114d99c413f8df680cb47ac628979f7a984a59b745fd

See more details on using hashes here.

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