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 API with implementations for local JSON and SQLite3 storage backends and a JSON convenience layer.
Quickstart
from nr.caching.stores.sqlite import SqliteStore
from nr.caching.adapters.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.4.0.tar.gz
(9.5 kB
view hashes)
Built Distribution
nr.caching-0.4.0-py3-none-any.whl
(10.4 kB
view hashes)
Close
Hashes for nr.caching-0.4.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | f0fe45fdca50de809ddd11ed2e79585bf8d8b2ebdc3ee204af3b19ba07fff4b6 |
|
MD5 | eb643e93500447592017d3b522e43117 |
|
BLAKE2b-256 | 7b0e35c8ca9671537045e3b06e8a26aa525407f5cd91739f7a0d5aa3848a70dc |