45

我想覆盖我的 Python 类__getattribute____setattr__方法。我的用例是通常的用例:我有一些我想要处理的特殊名称,并且我想要其他任何东西的默认行为。因为__getattribute__,似乎我可以简单地通过提高来请求默认行为AttributeError。但是,我怎样才能达到同样的效果__setattr__?这是一个简单的示例,实现一个具有不可变字段“A”、“B”和“C”的类。

class ABCImmutable(SomeSuperclass):
    def __getattribute__(self, name):
        if name in ("A", "B", "C"):
            return "Immutable value of %s" % name
        else:
            # This should trigger the default behavior for any other
            # attribute name.
            raise AttributeError()

    def __setattr__(self, name, value):
        if name in ("A", "B", "C"):
            raise AttributeError("%s is an immutable attribute.")
        else:
            # How do I request the default behavior?
            ???

问号用什么代替?对于旧式类,答案显然是self.__dict__[name] = value,但文档表明这对于新式类是错误的。

4

2 回答 2

49

它是

super(ABCImmutable, self).__setattr__(name, value)

在 Python 2 中,或

super().__setattr__(name, value)

在 Python 3 中。

此外,提高AttributeError不是您回退到. 你回退到默认值__getattribute__

return super(ABCImmutable, self).__getattribute__(name)

在 Python 2 或

return super().__getattribute__(name)

在 Python 3 上。

提升AttributeError跳过默认处理并转到__getattr__,或者AttributeError如果没有 ,则仅在调用代码中生成__getattr__

请参阅有关自定义属性访问的文档。

于 2011-08-12T15:15:32.020 回答
6

SomeSuperclass.__setattr__(self, name, value)?

于 2011-08-12T15:12:30.147 回答