File-based ORM for dataclasses.
Project description
Datafiles: A file-based ORM for dataclasses
Datafiles is a bidirectional serialization library for Python dataclasses that automatically synchronizes object instances to the filesystem using type annotations. It supports a variety of file formats with round-trip preservation of formatting and comments, where possible.
Usage
Take an existing dataclass such as this example from the documentation:
from dataclasses import dataclass
@dataclass
class InventoryItem:
"""Class for keeping track of an item in inventory."""
name: str
unit_price: float
quantity_on_hand: int = 0
def total_cost(self) -> float:
return self.unit_price * self.quantity_on_hand
and replace the decorator, including a directory pattern to synchronize instances:
from datafiles import datafile
@datafile("inventory/items/{self.name}.yml")
class InventoryItem:
"""Class for keeping track of an item in inventory."""
name: str
unit_price: float
quantity_on_hand: int = 0
def total_cost(self) -> float:
return self.unit_price * self.quantity_on_hand
Then, work with instances of the class as normal:
>>> item = InventoryItem("widget", 3)
# inventory/items/widget.yml
unit_price: 3.0
Changes to the object are automatically saved to the filesystem:
>>> item.quantity_on_hand += 100
# inventory/items/widget.yml
unit_price: 3.0
quantity_on_hand: 100
Changes to the filesystem are automatically reflected in the object:
# inventory/items/widget.yml
unit_price: 2.5 # was 3.0
quantity_on_hand: 100
>>> item.unit_price
2.5
Demo: Jupyter Notebook
Installation
Because datafiles relies on dataclasses and type annotations, Python 3.7+ is required. Install it directly into an activated virtual environment:
$ pip install datafiles
or add it to your Poetry project:
$ poetry add datafiles
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 datafiles-0.1a10-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 93f08ce1bccfec672eb86f7cb253b04b7f25de5ee7d593713aea27d93742e785 |
|
MD5 | 182c825c55ceb5db69018a9e36bbf521 |
|
BLAKE2b-256 | 9a22fcbfc632b9f41de1fd0dfb80a0a0f6a7c9aed7f244bc439d9aa5d1bb221c |