Simple, fast, and space-efficient (de)serialization for simple Python classes
Project description
Miniserial
Miniserial is a Python package for dead-simple, space-efficient serialization
and deserialization of simple dataclasses. There are many great packages for
general purpose serialization in the standard library and on PyPI (e.g. json
,
marshal
, pickle
, ujson
, bson
, etc.), but most use serialization
formats that can come with significant byte overhead. Sometimes, project
constraints—like the 256-byte-max-packet radio devices that inspired this
package—encourage the use of a much more compact format, something akin to
protobuf or the layout of C structs. But libraries in this space typically come
with the overhead of implementing manual serializers, modifying class fields
with various wrappers, or using non python data specifications (e.g. .proto
files). msgpack
comes close, but does not work out of the box with classes.
Miniserial makes compact serialization easy. Simply have your
dataclass inherit from the Serialization
mixin, and serialize
and
deserialize
methods will be automatically generated for the class.
For example:
from dataclasses import dataclass
from miniserial import Serializable
@dataclass
class Person(Serializable):
name : str
age : int
titles : list[str]
balance: float
p = Person("Bob", 34, ["Mr.", "Dr.", "Professor"], 239847.25)
assert Person.deserialize(p.serialize()) == p
Classes that inherit the Serializable
mixin must be dataclasses composed of
fields annotated with supported types, which include any other class which
inherits Serializable
. This means that even recursive structures,
like trees, can be serialized and deserialized.
from __future__ import annotations
from dataclasses import dataclass
from miniserial import Serializable
@dataclass
class Node(Serializable):
value : int
children: list[Node]
# 1
# / \
# 2 3
# / \
# 4 5
tree = Node(1, [Node(2, [Node(4, []), Node(5, [])]), Node(3, [])])
assert Node.deserialize(tree.serialize()) == tree
Documentation of supported types and the serialization format is on the way. For
now, bool
, int
, float
, str
, and subclasses of collections.abc.Collection
(e.g. list
, set
, tuple
) are supported, along with any other user-defined
class that inherits Serializable
. int
and float
are taken to be 32 bit
values. Support for more types, including int64
, float64
, etc. from numpy
are on the horizon.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file miniserial-0.2.4.tar.gz
.
File metadata
- Download URL: miniserial-0.2.4.tar.gz
- Upload date:
- Size: 5.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d4674a679884f900b10349dcad5ef8334c297b07e36baf4d4c7607527c6c528b |
|
MD5 | da21c975490d143ed0ba824e744e0ae4 |
|
BLAKE2b-256 | af3f8fcd13a3982f56a021855e954ac48ddb87f5de9da88be2829438174013cf |
File details
Details for the file miniserial-0.2.4-py3-none-any.whl
.
File metadata
- Download URL: miniserial-0.2.4-py3-none-any.whl
- Upload date:
- Size: 5.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 78256adef0bdb0b53d8fbbe7fd199b6db5576c344d0275e54b25d870e888afae |
|
MD5 | 588ce7854144d631bee9f424b44c3ca1 |
|
BLAKE2b-256 | dde262eaa4a92b19e7cfe1e0bee635b6d3cf44c64ac760fb6ae92b012b85ba68 |