Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/marshmallow-code/marshmallow
A lightweight library for converting complex objects to and from simple Python datatypes.
https://github.com/marshmallow-code/marshmallow
deserialization marshalling python python-3 schema serde serialization validation
Last synced: 6 days ago
JSON representation
A lightweight library for converting complex objects to and from simple Python datatypes.
- Host: GitHub
- URL: https://github.com/marshmallow-code/marshmallow
- Owner: marshmallow-code
- License: mit
- Created: 2013-11-10T21:32:24.000Z (about 11 years ago)
- Default Branch: dev
- Last Pushed: 2024-10-25T22:34:03.000Z (3 months ago)
- Last Synced: 2024-10-29T15:44:37.359Z (3 months ago)
- Topics: deserialization, marshalling, python, python-3, schema, serde, serialization, validation
- Language: Python
- Homepage: https://marshmallow.readthedocs.io/
- Size: 5.8 MB
- Stars: 7,028
- Watchers: 80
- Forks: 628
- Open Issues: 175
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGELOG.rst
- Contributing: CONTRIBUTING.rst
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
- Authors: AUTHORS.rst
Awesome Lists containing this project
- best-of-python - GitHub - 14% open · ⏱️ 06.06.2024): (Data Serialization)
- awesome-starred - marshmallow - A lightweight library for converting complex objects to and from simple Python datatypes. (Python)
- awesome-starts - marshmallow-code/marshmallow - A lightweight library for converting complex objects to and from simple Python datatypes. (Python)
- awesome-django-performance - marshmallow - An ORM/ODM/framework-agnostic library for converting complex datatypes, such as objects, to and from native Python datatypes. (Serialization / Tools)
- awesome-list - marshmallow - A lightweight library for converting complex objects to and from simple Python datatypes. (Data Format & I/O / For Python)
- awesome-python-models - marshmallow - A lightweight library for converting complex objects to and from simple Python datatypes. (Model, Schema)
- awesome-python-decorator - marshmallow
- awesome-pyramid - marshmallow - A (Forms)
- starred-awesome - marshmallow - A lightweight library for converting complex objects to and from simple Python datatypes. (Python)
- jimsghstars - marshmallow-code/marshmallow - A lightweight library for converting complex objects to and from simple Python datatypes. (Python)
README
********************************************
marshmallow: simplified object serialization
********************************************|pypi| |build-status| |pre-commit| |docs|
.. |pypi| image:: https://badgen.net/pypi/v/marshmallow
:target: https://pypi.org/project/marshmallow/
:alt: Latest version.. |build-status| image:: https://github.com/marshmallow-code/marshmallow/actions/workflows/build-release.yml/badge.svg
:target: https://github.com/marshmallow-code/marshmallow/actions/workflows/build-release.yml
:alt: Build status.. |pre-commit| image:: https://results.pre-commit.ci/badge/github/marshmallow-code/marshmallow/dev.svg
:target: https://results.pre-commit.ci/latest/github/marshmallow-code/marshmallow/dev
:alt: pre-commit.ci status.. |docs| image:: https://readthedocs.org/projects/marshmallow/badge/
:target: https://marshmallow.readthedocs.io/
:alt: Documentation.. start elevator-pitch
**marshmallow** is an ORM/ODM/framework-agnostic library for converting complex datatypes, such as objects, to and from native Python datatypes.
.. code-block:: python
from datetime import date
from pprint import pprintfrom marshmallow import Schema, fields
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, 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
==========.. code-block:: shell-session
$ pip install -U marshmallow
.. end elevator-pitch
Documentation
=============Full documentation is available at https://marshmallow.readthedocs.io/ .
Ecosystem
=========A list of marshmallow-related libraries can be found at the GitHub wiki here:
https://github.com/marshmallow-code/marshmallow/wiki/Ecosystem
Credits
=======Contributors
------------This project exists thanks to all the people who contribute.
**You're highly encouraged to participate in marshmallow's development.**
Check out the `Contributing Guidelines `_ to see how you can help.Thank you to all who have already contributed to marshmallow!
.. image:: https://opencollective.com/marshmallow/contributors.svg?width=890&button=false
:target: https://marshmallow.readthedocs.io/en/latest/authors.html
:alt: ContributorsBackers
-------If you find marshmallow useful, please consider supporting the team with
a donation. Your donation helps move marshmallow forward.Thank you to all our backers! [`Become a backer`_]
.. _`Become a backer`: https://opencollective.com/marshmallow#backer
.. image:: https://opencollective.com/marshmallow/backers.svg?width=890
:target: https://opencollective.com/marshmallow#backers
:alt: BackersSponsors
--------.. start sponsors
marshmallow is sponsored by `Route4Me `_.
.. image:: https://github.com/user-attachments/assets/018c2e23-032e-4a11-98da-8b6dc25b9054
:target: https://route4me.com
:alt: Routing PlannerSupport this project by becoming a sponsor (or ask your company to support this project by becoming a sponsor).
Your logo will be displayed here with a link to your website. [`Become a sponsor`_].. _`Become a sponsor`: https://opencollective.com/marshmallow#sponsor
.. end sponsors
Professional Support
====================Professionally-supported marshmallow is now available through the
`Tidelift Subscription `_.Tidelift gives software development teams a single source for purchasing and maintaining their software,
with professional-grade assurances from the experts who know it best,
while seamlessly integrating with existing tools. [`Get professional support`_].. _`Get professional support`: https://tidelift.com/subscription/pkg/pypi-marshmallow?utm_source=marshmallow&utm_medium=referral&utm_campaign=github
.. image:: https://user-images.githubusercontent.com/2379650/45126032-50b69880-b13f-11e8-9c2c-abd16c433495.png
:target: https://tidelift.com/subscription/pkg/pypi-marshmallow?utm_source=pypi-marshmallow&utm_medium=readme
:alt: Get supported marshmallow with TideliftProject Links
=============- Docs: https://marshmallow.readthedocs.io/
- Changelog: https://marshmallow.readthedocs.io/en/latest/changelog.html
- Contributing Guidelines: https://marshmallow.readthedocs.io/en/latest/contributing.html
- PyPI: https://pypi.org/project/marshmallow/
- Issues: https://github.com/marshmallow-code/marshmallow/issues
- Donate: https://opencollective.com/marshmallowLicense
=======MIT licensed. See the bundled `LICENSE `_ file for more details.