Python serialization for adults
Project description
Camel is a library that lets you describe how to serialize your objects to YAML — and refuses to serialize them if you don’t.
Quick example:
from camel import Camel, CamelRegistry
class DieRoll(tuple):
def __new__(cls, a, b):
return tuple.__new__(cls, [a, b])
def __repr__(self):
return "DieRoll(%s,%s)" % self
reg = CamelRegistry()
@reg.dumper(DieRoll, u'roll', version=None)
def _dump_dice(data):
return u"{}d{}".format(*data)
@reg.loader(u'roll', version=None)
def _load_dice(data, version):
a, _, b = data.partition(u'd')
return DieRoll(int(a), int(b))
value = DieRoll(3, 6)
camel = Camel([reg])
print(camel.dump(value))
# !roll 3d6
# ...
Docs: http://camel.readthedocs.org/en/latest/
GitHub: https://github.com/eevee/camel
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
camel-0.1.1.tar.gz
(7.3 kB
view hashes)
Built Distribution
camel-0.1.1-py2.py3-none-any.whl
(23.1 kB
view hashes)
Close
Hashes for camel-0.1.1-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 44765c6ff86232b6c976a5cbcf9c268e42357fba6d803eb9e2555a016c527e03 |
|
MD5 | c5b80c7d1cd87e4dfc3057446387d910 |
|
BLAKE2b-256 | b48cb0449e46f711a2bd2a9d5489246b102961a6ead1e58917148a4927ffed2f |