Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

cfgparser

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

cfgparser

Python package that allows to parse typed configs defined by python dataclasses

  • 1.0.8
  • Source
  • PyPI
  • Socket score

Maintainers
1

PythonConfigParser

truly fully-typed python configs - not more, not less.

PyPI version Badge Name codecov

Usage

  1. define your config structure in a dataclass like
from dataclasses import dataclass
from typing import List

@dataclass
class DummyConfigElement:
    name: str
    list: List[int]
    another_list: List[float]

  1. initialize the config parser with the path to the module with the config definitions.

parser = ConfigParser(datastructure_module_name="mysrc.datastructures.configs")
  1. parse a config from file or dict
from file

my_config = parser.parse_from_file("myconfig.json")

from dictionary

my_config_dict = {"type_name" : "mysrc.datastructures.configs.a", "value" : 1}
my_config = parser.parse(my_config_dict)

Type definition

There are two ways to define the configs type:

  • specified in the config itself
    • store fully qualified name of the config class under the key "type_name" in the config
    • e.g in the code example above
  • specified when parsing the config
    • if the config has no key "typed_config" set, the type can be specified when parsing the config
from mysrc.datastructures.configs import a
my_config_dict = {"some_key" : "some_value"}
# config has no key "type_name" but type is specified when parsing
my_config = ConfigParser().parse_typed(my_config_dict,a)

Optional & Union fields

By default every field can be explicitly set to None. If you don't what this behavior you can set the flag "allow_none" to False.

    from cfgparser import settings
    settings.allow_none = False
Union fields

Whenever a Union type is encountered the parser tries to parse the config with the first type in the union. If this fails it tries the next type and so on. If all types fail the parser raises an exception. For instance, in the example below the parser tries to parse the config as a Bird. If this fails it tries to parse it as a Cat. If this fails too the parser raises an exception.


from dataclasses import dataclass
from typing import Union

@dataclass
class Bird:
    name: str
    wingspan: float

@dataclass
class Cat:
    name: str
    paws: int

@dataclass
class AnimalOwnership:
    owner: str
    animal : Union[Bird, Cat]

Features

  • ✅ fully typed json and yaml configs
  • ✅ nested configs
  • ✅ complex union and optional types
  • ✅ dict object into typed dataclass
  • ✅ support for enums (value given as string or int)
  • ✅ support for typed tuples (e.g. Tuple[int, str, float])
  • ✅ override type_name if type is specified when parsing

Installation

pip install cfgparser

Feature Roadmap

  • ⬜ specify config from cli
  • ⬜ post hock
  • ⬜ distributed configs
  • ⬜ typed dicts (e.g. Dict[str, MyType])
  • ⬜ typed functions (e.g. torch.functional.relu)
  • ⬜ save config to file (json, yaml) with and without typeinfo

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc