Skip to main content

Extensible memoizing collections and decorators

Project description

This module provides various memoizing collections and decorators, including variants of the Python 3 Standard Library @lru_cache function decorator.

from cachetools import cached, LRUCache, TTLCache

# speed up calculating Fibonacci numbers with dynamic programming
@cached(cache={})
def fib(n):
    return n if n < 2 else fib(n - 1) + fib(n - 2)

# cache least recently used Python Enhancement Proposals
@cached(cache=LRUCache(maxsize=32))
def get_pep(num):
    url = 'http://www.python.org/dev/peps/pep-%04d/' % num
    with urllib.request.urlopen(url) as s:
        return s.read()

# cache weather data for no longer than ten minutes
@cached(cache=TTLCache(maxsize=1024, ttl=600))
def get_weather(place):
    return owm.weather_at_place(place).get_weather()

For the purpose of this module, a cache is a mutable mapping of a fixed maximum size. When the cache is full, i.e. by adding another item the cache would exceed its maximum size, the cache must choose which item(s) to discard based on a suitable cache algorithm. In general, a cache’s size is the total size of its items, and an item’s size is a property or function of its value, e.g. the result of sys.getsizeof(value). For the trivial but common case that each item counts as 1, a cache’s size is equal to the number of its items, or len(cache).

Multiple cache classes based on different caching algorithms are implemented, and decorators for easily memoizing function and method calls are provided, too.

For more information, please refer to the online documentation.

Installation

Install cachetools using pip:

pip install cachetools

Project Resources

Latest PyPI version Travis CI build status Test coverage Documentation Status

License

Copyright (c) 2014-2019 Thomas Kemmer.

Licensed under the MIT License.

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

cachetools-3.1.0.tar.gz (20.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cachetools-3.1.0-py2.py3-none-any.whl (12.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file cachetools-3.1.0.tar.gz.

File metadata

  • Download URL: cachetools-3.1.0.tar.gz
  • Upload date:
  • Size: 20.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.23.3 CPython/3.6.7

File hashes

Hashes for cachetools-3.1.0.tar.gz
Algorithm Hash digest
SHA256 9efcc9fab3b49ab833475702b55edd5ae07af1af7a4c627678980b45e459c460
MD5 a7b1c5eb5390d50067c62d7bcb4e875c
BLAKE2b-256 0507c117b9527a0cd5beb7990fcdb7b0abf57e84f2d82eaf130921b43e594df4

See more details on using hashes here.

File details

Details for the file cachetools-3.1.0-py2.py3-none-any.whl.

File metadata

  • Download URL: cachetools-3.1.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 12.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.23.3 CPython/3.6.7

File hashes

Hashes for cachetools-3.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 219b7dc6024195b6f2bc3d3f884d1fef458745cd323b04165378622dcc823852
MD5 86700bcfe788e5f7dcc0cd9e3b38fc78
BLAKE2b-256 392bd87fc2369242bd743883232c463f28205902b8579cb68dcf5b11eee1652f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page