为了账号安全,请及时绑定邮箱和手机立即绑定

将返回自我的函数装饰器?

将返回自我的函数装饰器?

慕婉清6462132 2021-11-09 11:03:18
我必须遵循将使用从类变量派生的可链接方法创建对象的类。由于这个代码是相当重复的,我的挑战就是如何能够在应用方法的装饰a,b和c。我面临的问题是我似乎无法找到一种方法来构造将返回实例 ( self)的包装器。有没有更好的方法来构建它?class Test:    def __init__(self, a, b, c):        self._a = a        self._b = b        self._c = c        self.call_chain = []    def a(self, truth):        def func():            return self._a == truth        self.call_chain.append(func)        return self    def b(self, truth):        def func():            return self._b == truth        self.call_chain.append(func)        return self    def c(self, val):        def func():            return self._c == val        self.call_chain.append(func)        return self    def evaluate(self):        try:            for f in self.call_chain:                if f() == False:                    raise ValueError('False encountered')        except ValueError:            self.call_chain.clear()            return False         self.call_chain.clear()        return True它像这样链接起来:c = Test(True, False, 13)c.a(True).b(False).c(13).evaluate()
查看完整描述

1 回答

?
FFIVE

TA贡献1797条经验 获得超6个赞

诀窍是将函数的参数存储为调用链的一部分。最简单的方法是使用functools.partial对象。


from functools import wraps, partial


def chain(func):

    @wraps(func)

    def wrapper(self, *args, **kwargs):

        suspended = partial(func, self, *args, **kwargs)

        self.call_chain.append(suspended)

        return self

    return wrapper


class Test:

    def __init__(self, a, b, c):

        self.call_chain = []

        self._a = a

        self._b = b

        self._c = c

    @chain

    def a(self, val):

        return self._a == val

    @chain

    def b(self, val):

        return self._b == val

    @chain

    def c(self, val):

        return self._c == val

    def evaluate(self):

        try:

            for f in self.call_chain:

                if f() == False:

                    raise ValueError('False encountered')

        except ValueError:

            self.call_chain.clear()

            return False 

        self.call_chain.clear()

        return True


c = Test(True, False, 13)

c.a(True).b(False).c(13).evaluate()  # True

c.a(True).b(False).c(11).evaluate()  # False


查看完整回答
反对 回复 2021-11-09
  • 1 回答
  • 0 关注
  • 150 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号