Skip to main content

A serialization library for Python

Project description

Serialite

Serialite is a library serializing and deserializing arbitrarily complex objects in Python. You apply the @serializable decorator to a dataclass to automatically create to_data and from_data methods using the type annotations. Or for more control, inherit from the SerializableMixin and implement the class attribute __fields_serializer__. For even more control, inherit from the abstract base class Serializer and implement the to_data and from_data methods directly.

Basics

The abstract base class is Serializer:

class Serializer(Generic[Output]):
    def from_data(self, data: Json) -> DeserializationSuccess[Output]: ...
    def to_data(self, value: Output) -> Json: ...

The class is generic in the type of the object that it serializes. The two abstract methods from_data and to_data are the key to the whole design, which revolves around getting objects to and from JSON-serializable data, which are objects constructed entirely of bools, ints, floats, lists, and dicts. Such structures can be consumed by json.dumps to produce a string and produced by json.loads after consuming a string. By basing the serialization around JSON serializable data, complex structures can be built up or torn down piece by piece while alternatively building up complex error messages during deserialization which pinpoint the location in the structure where the bad data exist.

For new classes, it is recommended that the Serializer be implemented on the class itself. There is an abstract base class Serializable that classes can inherit from to indicate this. There is a mixin SerializableMixin that provides an implementation of from_data and to_data for any class that implements the __fields_serializer class attribute.

For dataclasses, it is even easier. There is a decorator serializable that inserts SerializableMixin into the list of base classes after the dataclass decorator has run and also generates __fields_serializer__ from the data class attributes.

Finding the correct serializer for each type can be a pain, so serializer(cls: type) -> Serializer is provided as a convenience function. This is a single dispatch function, which looks up the serializer registered for a particular type. For example, serializer(list[float]) will return ListSerializer(FloatSerializer).

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

serialite-0.6.2.tar.gz (25.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

serialite-0.6.2-py3-none-any.whl (40.8 kB view details)

Uploaded Python 3

File details

Details for the file serialite-0.6.2.tar.gz.

File metadata

  • Download URL: serialite-0.6.2.tar.gz
  • Upload date:
  • Size: 25.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for serialite-0.6.2.tar.gz
Algorithm Hash digest
SHA256 fa566f3df6ced591d1e60afcdf031e04d56331b9aabaab4723f5a8c6eedcbe3b
MD5 06f2e432003ce8c4d230388ae25a8d59
BLAKE2b-256 b3a9c352e178f11313800126a8324823546e80287b46b6b4183c6449926e8985

See more details on using hashes here.

Provenance

The following attestation bundles were made for serialite-0.6.2.tar.gz:

Publisher: release.yml on drhagen/serialite

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file serialite-0.6.2-py3-none-any.whl.

File metadata

  • Download URL: serialite-0.6.2-py3-none-any.whl
  • Upload date:
  • Size: 40.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for serialite-0.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 a12a507c8c719cc49bc61e77e612849db997215981e15eb3b7cabd133042858c
MD5 dcd325c33f3dc1614054535a9a0ebc7f
BLAKE2b-256 48e21e045a6821c00e7432ee5390d15952da0e960c7c2cf9e8b9160aa8a25aab

See more details on using hashes here.

Provenance

The following attestation bundles were made for serialite-0.6.2-py3-none-any.whl:

Publisher: release.yml on drhagen/serialite

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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