A simple key-value caching API with default implementations for an SQLite3 storage backend and a JSON convenience layer.
Project description
Note: This package is in the dangerous land of
0.x.y
versions and may be subject to breaking changes with minor version increments.
nr.caching
A simple key-value caching API with default implementations for an SQLite3 storage backend and a JSON convenience layer.
Quickstart
from nr.caching.sqlite import SqliteStore
from nr.caching.json import hash_args, JsonCacheFactory
caching_backend = SqliteStore('.cache.db')
cache_factory = JsonCacheFactory(caching_backend, default_exp=60)
data = cache_factory.namespace('my-namespace').loading(
f'expensive_function_{hash_args(parameters)}',
lambda: expensive_function(*parameters))
Copyright © 2021 Niklas Rosenstein
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
nr.caching-0.3.2.tar.gz
(7.6 kB
view hashes)
Built Distribution
Close
Hashes for nr.caching-0.3.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | ba0cc1daf5e50c365fb881e907013d44e4a94c842bc7c517fc63ea4f19c5a601 |
|
MD5 | 41bd7fc6d74b562f0cb66254206139b5 |
|
BLAKE2b-256 | 26c8b252032c912eea85344dba36a233c85d09e0b30acca73cefca104d38e3d2 |