A lightweight library for converting complex datatypes to and from native Python datatypes.
Project description
marshmallow is an ORM/ODM/framework-agnostic library for converting complex datatypes, such as objects, to and from native Python datatypes.
from datetime import date
from marshmallow import Schema, fields, pprint
class ArtistSchema(Schema):
name = fields.Str()
class AlbumSchema(Schema):
title = fields.Str()
release_date = fields.Date()
artist = fields.Nested(ArtistSchema())
bowie = dict(name='David Bowie')
album = dict(artist=bowie, title='Hunky Dory', release_date=date(1971, 12, 17))
schema = AlbumSchema()
result = schema.dump(album)
pprint(result.data, indent=2)
# { 'artist': {'name': 'David Bowie'},
# 'release_date': '1971-12-17',
# 'title': 'Hunky Dory'}
In short, marshmallow schemas can be used to:
Validate input data.
Deserialize input data to app-level objects.
Serialize app-level objects to primitive Python types. The serialized objects can then be rendered to standard formats such as JSON for use in an HTTP API.
Get It Now
$ pip install -U marshmallow --pre
Documentation
Full documentation is available at http://marshmallow.readthedocs.io/ .
Requirements
Python >= 2.7 or >= 3.4
marshmallow has no external dependencies outside of the Python standard library, although python-dateutil is recommended for robust datetime deserialization.
Ecosystem
A list of marshmallow-related libraries can be found at the GitHub wiki here:
https://github.com/marshmallow-code/marshmallow/wiki/Ecosystem
Project Links
License
MIT licensed. See the bundled LICENSE file for more details.
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
Hashes for marshmallow-3.0.0b5-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | cfd9c20225f3acd7457bf72fea931852cc8bf5a511cb75dd546cec773fb19a0a |
|
MD5 | 252cd317957fb2a83f63c9c283d65ed0 |
|
BLAKE2b-256 | 7f31a9e75aa74347bdefc078ed61e33ba6e2ba8c38d78f6578204ce300c11ff8 |