python - 子类化 Python 的 `property`

标签 python properties

在我的一门类(class)中,我有许多属性在获取和设置方面执行非常相似的操作。所以我把 property 的参数抽象成一个工厂函数:

def property_args(name):
    def getter(self):
        # do something
        return getattr(self, '_' + name)
    def setter(self, value)
        # do something
        setattr(self, '_' + name, value)
    return getter, setter

class MyClass(object):
    def __init__(self):
        self._x = None
    x = property(*property_args('x'))  # obviously there's more than one of these IRL

然而,我后来发现 property 实际上是一个类,并且对它进行子类化将是完美的。我在文档中找不到任何解释我需要覆盖的内容(以及 __init__ 等的参数签名),我真的不想在 C 源代码中寻找为了它。有谁知道我在哪里可以找到这些信息?

最佳答案

这是 property() 中代码的纯 Python 等价物:

class Property(object):
    "Emulate PyProperty_Type() in Objects/descrobject.c"

    def __init__(self, fget=None, fset=None, fdel=None, doc=None):
        self.fget = fget
        self.fset = fset
        self.fdel = fdel
        if doc is None and fget is not None:
            doc = fget.__doc__
        self.__doc__ = doc

    def __get__(self, obj, objtype=None):
        if obj is None:
            return self
        if self.fget is None:
            raise AttributeError("unreadable attribute")
        return self.fget(obj)

    def __set__(self, obj, value):
        if self.fset is None:
            raise AttributeError("can't set attribute")
        self.fset(obj, value)

    def __delete__(self, obj):
        if self.fdel is None:
            raise AttributeError("can't delete attribute")
        self.fdel(obj)

    def getter(self, fget):
        return type(self)(fget, self.fset, self.fdel, self.__doc__)

    def setter(self, fset):
        return type(self)(self.fget, fset, self.fdel, self.__doc__)

    def deleter(self, fdel):
        return type(self)(self.fget, self.fset, fdel, self.__doc__)

关于python - 子类化 Python 的 `property`,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12405087/

相关文章:

java - 使用同一个类 Spring 多个 @ConfigurationProperties

android - 如何在 android 中配置 java.util.logging.logger 以使用放置在 sdcard 上的日志记录属性文件?

python - 在 Ipython Notebook 中禁用 INFO 日志记录消息

python - 通过连接传播 pandas 系列元数据

python - 使用Python通过串口发送文件

javascript - 解构一个属性为 "delete"的对象

c# - 设置可空属性默认值的首选方法?

python - 如何制作不同大小、颜色、位置的散点图?

python - 元类与单继承冲突

JavaBeans:属性和特性之间有什么区别?