A library to handle persistent memory
Project description
membank
Python library for storing data in persistent memory (sqlite, postgresql, berkeley db)
goals
Provide interface to database storage that automates heavy lifting of database setup, migration, table definition, query construction.
quick intro
add items to persistent storage
import dataclasses as data # Python standard library
from membank import LoadMemory
@data.dataclass
class Dog():
breed: str
color: str = "black"
weight: float = 0
data: dict = data.field(default_factory=dict)
picture: bytes = b''
aliases: list = data.field(default_factory=list)
@data.dataclass
class DogWithID():
id: str = data.field(default=None, metadata={"key": True})
breed: str
color: str = "black"
weight: float = 0
data: dict = data.field(default_factory=dict)
picture: bytes = b''
alive: bool = True
memory = LoadMemory() # defaults to sqlite memory
memory.put(Dog('Puli')) # stores object into database
dog = memory.get.dog() # retrieves first object found
assert dog.breed == 'Puli'
dog.color = "white"
memory.put(dog) # be carefull you store another dog
dog = memory.put(DogWithID("AB1234", "Puli"))
dog = memory.get.dogwithid(id="AB1234")
dog.color = "white"
memory.put(dog) # now you update existing dog
retrieve those after
memory = LoadMemory() # to make this work in new process, don't use sqlite memory
dog = memory.get.dog() # get first found or None
assert dog.color == 'black'
dogs = memory.get("dog") # always returns list (empty or with items)
assert len(dogs) >= 0
editing returned objects
dog = memory.get.dog()
dog.breed = 'Labdrador'
memory.put(dog) # stores edited object back
filter objects
dog = memory.get.dog(breed='Labdrador')
assert dog.breed == 'Labrador'
Known issues
- return class is stored(pickled) into underlying database table with reference to the module to load it back. If module name or class name is changed, membank won't always be able to load previous data as object pointer could be missing
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
membank-0.5.0.tar.gz
(12.2 kB
view details)
Built Distribution
File details
Details for the file membank-0.5.0.tar.gz
.
File metadata
- Download URL: membank-0.5.0.tar.gz
- Upload date:
- Size: 12.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fac384f39d7a4799525f3a371c701db6c770836b2562072a44b403d650adebe2 |
|
MD5 | fecc65876203d59f26bc282fdb16e13c |
|
BLAKE2b-256 | bb72432d72b26e6fcc573c9ec5c1deb2961f160497691d5d22edbc000eb1e8d3 |
File details
Details for the file membank-0.5.0-py3-none-any.whl
.
File metadata
- Download URL: membank-0.5.0-py3-none-any.whl
- Upload date:
- Size: 9.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fff1fffabd51afea1ba519a881fa462c2bcf03eb8c60cd6b39d6c8da5ffc2d93 |
|
MD5 | e53e7d99fdb2b13a77e1b75ea4143e81 |
|
BLAKE2b-256 | cb8fdf9cd0971dc75d35ee5ef2a297a01542a878cb4b9936771eba2109efba61 |