Schemars is a Python package, written in Rust and leveraging PyO3, designed for efficient and flexible serialization of Python class instances. It provides a simple yet powerful schema-based approach to serialize complex Python objects.
To install Schemars, run the following command:
pip install schemars
- Python 3.x
- Rust (optional for development)
To use Schemars, define your Python class and corresponding schema class, then serialize instances as shown below:
class Product:
def __init__(self, name, price, created):
self.name = name
self.price = price
self.created = created
product = Product("test", 10, "1577836800")
import schemars
class ProductSchema(schemars.Schema):
name = schemars.Str(strict=True)
price = schemars.Decimal()
created = schemars.Date(format='%Y/%m/%d')
print(ProductSchema().serialize(product))
We are currently working on comprehensive documentation for Schemars, which will cover detailed usage, advanced features, and integration guides. Stay tuned for updates, and feel free to reach out to us with any specific questions or suggestions in the meantime.
In the upcoming Version 1.0 of Schemars, we will be introducing additional functionalities including both validation and deserialization. This enhancement aims to provide a more comprehensive and robust experience in handling and processing Python class instances.
Schemars was developed in response to performance challenges encountered with existing serialization tools like Marshmallow and Django REST Framework. Our goal was to create a solution that not only addresses these performance issues but also remains user-friendly and familiar.
If you're already using Marshmallow or Django REST Framework, you'll find Schemars's syntax and usage comfortably similar. This design choice is intentional to ensure that migration to Schemars is smooth and can be accomplished in just minutes. We have prioritized maintaining a familiar interface while significantly enhancing performance, so you can switch to Schemars with minimal adjustments to your existing codebase.
To compare Schemars with Django REST Framework (DRF), Marshmallow and Pydantic, follow these steps:
Install benchmarking requirements:
python3 -m pip install -r bench/requirements.txt
Execute the benchmark script:
python3 bench/run.py
This will run serialization tasks using Schemars, Marshmallow, DRF and Pydantic, allowing you to directly compare their performance.
Schemars is released under the [MIT License]