编程语言
首页 > 编程语言> > python – 有没有办法在ContextDecorator中访问函数的属性/参数?

python – 有没有办法在ContextDecorator中访问函数的属性/参数?

作者:互联网

我正在尝试使用Python的contextlib.ContextDecorator类编写上下文管理器装饰器.

有没有办法在上下文管理器中访问修饰函数的参数?

这是我正在做的一个例子:

from contextlib import ContextDecorator

class savePen(ContextDecorator):
    def __enter__(self):
        self.prevPen = self.dc.GetPen()     # AttributeError
        return self

    def __exit__(self, *exc):
        self.dc.SetPen(self.prevPen)
        return False

鉴于以上情况,这个:

@savePen()
def func(dc, param1, param2):
    # do stuff, possibly changing the pen style

应相当于:

def func(dc, param1, param2):
    prevPen = dc.GetPen()
    # do stuff, possibly changing the pen style
    dc.SetPen(prevPen)

我已经搜索了contextlib的文档并且没有找到任何有用的东西.

有谁知道如何从ContextDecorator类中访问修饰函数的属性?

EDIT1:

正如@chepner在this response所说,ContextDecorator是糖

def func(dc, param1, param2):
    with savePen():
        ...

并且它无法访问函数的参数.

但是,在这种情况下,使用savePen()运行的任何内容都可以访问函数参数dc,param1和param2.这让我觉得我应该能够使用ContextDecorator访问它们.

例如,这是有效的:

def func(dc, param1, param2):
    with savePen():
        print(param1)

解决方法:

contextlib.contextmanager似乎更合适.请注意,与其他任何内容一样,您无法从函数外部访问函数体的局部变量(无论如何都缺少内省黑客).

@contextlib.contextmanager
def savePen(dc):
    prevPen = dc.GetPen()
    yield
    dc.SetPen(prevPen)

with savePen(dc):
    func(dc, param1, param2)

请注意,使用ContextDecorator,上下文管理器实例化时不带参数,即

@savePen()
def func(dc, param1, param2):
    # do stuff, possibly changing the pen style

是语法糖(根据文件)

def func(dc, param1, param2):
    with savePen():
        ...

所以没有办法告诉savePen使用哪个对象(dc).

标签:python,python-3-x,contextmanager,python-decorators
来源: https://codeday.me/bug/20190708/1399500.html