Python类装饰器参数

我试图在 python中将可选参数传递给我的类装饰器.
在我现在的代码下面
class Cache(object):
    def __init__(self,function,max_hits=10,timeout=5):
        self.function = function
        self.max_hits = max_hits
        self.timeout = timeout
        self.cache = {}

    def __call__(self,*args):
        # Here the code returning the correct thing.


@Cache
def double(x):
    return x * 2

@Cache(max_hits=100,timeout=50)
def double(x):
    return x * 2

具有覆盖默认值的参数的第二个装饰器(max_hits = 10,__init__函数中的timeout = 5)不起作用,我得到异常TypeError:__init __()至少有两个参数(3个给定).我尝试了许多解决方案并阅读有关它的文章,但在这里我仍然无法使其工作.

有什么想法来解决吗?谢谢!

解决方法

@Cache(max_hits = 100,timeout = 50)调用__init __(max_hits = 100,timeout = 50),所以你不满足函数参数.

您可以通过一个检测函数是否存在的包装方法来实现您的装饰器.如果它找到一个函数,它可以返回Cache对象.否则,它可以返回将用作装饰器的包装器函数.

class _Cache(object):
    def __init__(self,*args):
        # Here the code returning the correct thing.

# wrap _Cache to allow for deferred calling
def Cache(function=None,timeout=5):
    if function:
        return _Cache(function)
    else:
        def wrapper(function):
            return _Cache(function,max_hits,timeout)

        return wrapper

@Cache
def double(x):
    return x * 2

@Cache(max_hits=100,timeout=50)
def double(x):
    return x * 2

相关文章

在这篇文章中,我们深入学习了XPath作为一种常见的网络爬虫技巧。XPath是一种用于定位和选择XML文档中特...
祝福大家龙年快乐!愿你们的生活像龙一样充满力量和勇气,愿你们在新的一年里,追逐梦想,勇往直前,不...
今天在爬虫实战中,除了正常爬取网页数据外,我们还添加了一个下载功能,主要任务是爬取小说并将其下载...
完美收官,本文是爬虫实战的最后一章了,所以尽管本文着重呈现爬虫实战,但其中有一大部分内容专注于数...
JSON是一种流行的数据传输格式,Python中有多种处理JSON的方式。官方的json库是最常用的,它提供了简单...
独立样本T检验适用于比较两组独立样本的均值差异,而配对T检验则适用于比较同一组样本在不同条件下的均...