Skip to main content

dict to/from dataclasses

Project description

dict2any

PyPI - Version PyPI - Python Version


Problem: You need to initialize a nested data structure (such as a dataclass containing another dataclass)

Solution: use dict2any.parse(MyClass, data) and it will recursively build up your data structure using type hints.

Usage

from dataclasses import dataclass
from dict2any import parse

@dataclass
class Package:
  name: str

@dataclass
class Config:
  packages: list[Package]

config = parse(Config, {"packages": [{"name": "wow"}, {"name": "amazing"}]})
print(config)
# Config(packages=[Package(name='wow'), Package(name='amazing')])

Advanced usage

Custom Parsing

The parsersargument lets you pass in additional parsers, to further customize or extend the functionality.

To do so, you must implement the Parser protocol. There are two methods: can_parse, and parse which you should implement. Take a look at any of the builtin parsers for inspiration

Implementing can_parse

The first parser which returns True to can_parse is the one that wins, and will parse that data type. Instead of a strict ordering (e.g try the DictParser, then the ListParser, etc etc.), the algorithm works in stages. It is expected that only one parser will match for a data type for a given stage. The stages are as follows:

  • Override: This stage is checked first. No builtin parsers use this stage. Instead, it's an opportunity for any custom parsers to "win" and be the one chosen to parse a data type
  • Exact: This parser knows how to parse this exact data type. For example, a certain class, or when an object is a certain type
  • Fallback: The parser is a little more generic, and handles subclasses or other coerceable classes.
  • LastChance: Generically try to handle all classes

For example, the DictParser can_parse the following types in Stage.Exact:

  • dict
  • OrderedDict
  • dict[str, str]

and it can additionally parse the following types in Stage.Fallback:

  • TypedDict
  • UserDict
  • class MyDict(dict)
  • Any class which implements collections.abc.Mapping or collections.abc.MutableMapping

Alternative solutions

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

dict2any-0.0.2.tar.gz (9.4 kB view hashes)

Uploaded Source

Built Distribution

dict2any-0.0.2-py3-none-any.whl (12.3 kB view hashes)

Uploaded 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