Les décorateurs de mémorisation suivants sont introduits dans Pythonwiki.
# note that this decorator ignores **kwargs
def memoize(obj):
cache = obj.cache = {}
@functools.wraps(obj)
def memoizer(*args, **kwargs):
if args not in cache:
cache[args] = obj(*args, **kwargs)
return cache[args]
return memoizer
Cependant, comme indiqué dans le commentaire, il semble qu'il ne supporte pas les kwargs. Traitons-y.
# do not use "self" for a name of argument.
import inspect
def memoize(obj):
cache = obj.cache = {}
@functools.wraps(obj)
def memoizer(*args, **kwargs):
argdict = inspect.getcallargs(obj, *args, **kwargs)
argdict.pop('self', None) # if obj is a bound method, arguments includes "self"
argset = frozenset(argdict.iteritems()) # for Python3, use dict.items() instead
if argset not in cache:
cache[argset] = obj(*args, **kwargs)
return cache[argset]
return memoizer
Le but est d'utiliser la bibliothèque standard inspect. inspect.getcallargs ()
>>> def f(a, b, c=10):
... pass
...
>>> inspect.getcallargs(f, 1, 2)
{'a': 1, 'c': 10, 'b': 2}
Comme, il transforme le nom de l'argument et l'argument dans un dictionnaire. inspect est utile à bien des égards.
Recommended Posts