Skip to main content

A Python package that standardizes data parsing from multiple serialized formats into pydantic models.

Project description

SerialBus

SerialBus is a Pydantic-based tool designed to act as a conduit between serialized data and Python objects. It not only facilitates the transformation of complex serialized data into Python objects, but also ensures stringent data validation. Think of it as the coach that transports your data from the realm of serialization into the world of Python, and vice-versa, all the while maintaining the integrity and structure of your data.

Install

pip:

pip install serial_bus

poetry:

poetry add serial_bus

Features

  • Pydantic Integration: Converting serialized data into Python objects is the oldest trick in the book, but SerialBus elevates this process by directly converting the data into Pydantic models, which brings the added advantage of robust data validation. The models used in this process are defined by classes that inherit from either the SerialBusBaseModel or SerialBusRenderableModel. This not only provides flexibility in setting up behaviors for your data, but also ensures data integrity through Pydantic's validation mechanisms.

  • Built-in Support for Multiple Formats: Currently, it supports loading serialized data from JSON, YAML, TOML and INI. While future support for other formats is planned, if you need to cover additional formats, or even provide your own parsing business logic, this can be easily achieved by extending SerialBusbasic coverage with your own loader and/or dumper functions. Speaking of which...

  • Extensibility: The code was thought to allow for ease of extensibility. For more information and examples, refer to the documentation below.

SerialBus

Quick Start

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

serial_bus-0.1.0.tar.gz (19.8 kB view hashes)

Uploaded Source

Built Distribution

serial_bus-0.1.0-py3-none-any.whl (26.2 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page