Implementation of Slotted Data Classes compatible with Python 2.7 and 3.7+.
Project description
Overview
Immutable data structures based on estruttura.
Examples
>>> from datta import Data, attribute
>>> class Point(Data):
... x = attribute(types=int)
... y = attribute(types=int)
...
>>> point_a = Point(3, 4)
>>> point_a
Point(3, 4)
>>> point_b = point_a.update(x=30, y=40)
>>> point_b
Point(30, 40)
>>> from datta import Data, attribute, list_attribute
>>> from tippo import Literal
>>> class Vehicle(Data):
... kind = attribute(types=str)
...
>>> class Garage(Data):
... vehicles = list_attribute(types=Vehicle)
... gate = attribute(default="automatic", types=str) # type: Literal["automatic", "manual"]
...
>>> garage = Garage([Vehicle("bicycle"), Vehicle("car")], gate="manual")
>>> garage
Garage([Vehicle('bicycle'), Vehicle('car')], gate='manual')
>>> garage.serialize() == {"vehicles": [{"kind": "bicycle"}, {"kind": "car"}], "gate": "manual"}
True
>>> Garage.deserialize({"vehicles": [{"kind": "bicycle"}, {"kind": "car"}], "gate": "manual"}) == garage
True
>>> from datta import list_cls
>>> MyStrList = list_cls(converter=str, qualified_name="MyStrList")
>>> my_str_list = MyStrList([1, 2.2, None, True])
>>> my_str_list
MyStrList(['1', '2.2', 'None', 'True'])
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
datta-1.0.0.tar.gz
(12.3 kB
view hashes)
Built Distribution
datta-1.0.0-py2.py3-none-any.whl
(14.8 kB
view hashes)
Close
Hashes for datta-1.0.0-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | f21447f2cf650294d800bc00884a0fe1c67ae91dc28646f1ba9bfbbc37a8fdd0 |
|
MD5 | d90d7306ed6a90bc6d590e6e9fbcd2b1 |
|
BLAKE2b-256 | 0cabfc17e29f5e3626359064966718f3f2a77e30a6179cf9d2804aacb2e109fc |