TTLMemoized - a memoized decorator with TTL (time-to-live) support
Project description
TTL Memoized - A memoized decorator with TTL (time-to-live) support.
The idea of memoized is great, as some resources are expensive, so you want to cache them.
However, there isn’t a memoized lib support TTL (time-to-live) at the moment, or I haven’t find any thing yet.
So I implement this lib to fill in the gap here.
Installation:
Should be faily simple using pip:
pip install ttl_memoized
Usage
The usage is simple, and the best way to explain it, is with my test cases:
def test_basic(): @memoized(ttl=0.5) def a(name): return datetime.datetime.now() @memoized(ttl=0.5) def b(name, *args, **kwargs): return datetime.datetime.now() a1 = a(1) b1 = b(1, 2, 3, what='ever', you='want', to='be') for i in range(100): assert a1 == a(1) for i in range(100): assert b1 is b(1, 2, 3, what='ever', you='want', to='be') a2 = a(2) assert a2 != a1 # let the cache expired... time.sleep(0.51) assert a(1) != a1 assert b1 != b(1, 2, 3, what='ever', you='want', to='be')
Ceveat
The parameter for the functions is required to be serializable with json libs, as the lib is using json to build the keys from parameters.
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 Distributions
No source distribution files available for this release.See tutorial on generating distribution archives.
Built Distribution
Close
Hashes for ttl_memoized-0.2.0-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | da1de372fc4659481485772caf127ee0b82ad3ee4691e894d441e7a5421bc475 |
|
MD5 | 799153b29fa3ffa96f1a74cd695a5fa0 |
|
BLAKE2b-256 | 099d30909174c1ca1a20c49c7fdb16b8309a4a29cb47666b1d41267830f54337 |