Skip to content

lordjabez/file-memoizer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

58 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

File Memoizer

license PyPi:version Tests Release

NOTICE: This package is deprecated and will no longer be updated, as the functionality it provides has now been inplemented directly in cachier. Please use that package directly.

Installation

Installation is via pip:

pip install file-memoizer

Usage

To cache a function's value, annotate it by calling the memoize function as follows. Note that all function arguments must be hashable for it to be cached else a TypeError will be thrown.

import file_memoizer

@file_memoizer.memoize()
def double(n):
    return 2 * n

By default the cached values remain valid for a day. This can be changed with the cache_ttl parameter:

import datetime
import file_memoizer

seven_days = cache_ttl=datetime.timedelta(days=7)

@file_memoizer.memoize(cache_ttl=seven_days)
def triple(n):
    return 3 * n

Cache files are stored in $HOME/.file-memoizer, with one file per combination of input parameters. An alternate location can be specified with the cache_directory parameter:

import datetime
import file_memoizer

custom_path = '/path/to/store/files'

@file_memoizer.memoize(cache_directory=custom_path)
def quadruple(n):
    return 4 * n

The memoizer will automatically ignore a function's first parameter if named self, so that instance methods can be cached. It is the caller's responsibility to ensure the result of the method does not depend on the state of the object's internals. This is most useful when the object is being used to call an external service.

import requests

class ExampleAPIClient():

    @file_memoizer.memoize()
    def get(self, url):
        return self.session.get(url)

    def __init__(self):
        self.session = requests.Session()

About

Python utility for using files to cache function results across executions

Resources

License

Stars

Watchers

Forks

Packages

No packages published