子类化Python';s的财产`
在我的一个类中,我有许多属性,它们在获取和设置时执行非常类似的操作。因此,我将子类化Python';s的财产`,python,properties,Python,Properties,在我的一个类中,我有许多属性,它们在获取和设置时执行非常类似的操作。因此,我将property的参数抽象为一个工厂函数: def property_args(name): def getter(self): # do something return getattr(self, '_' + name) def setter(self, value) # do something setattr(self, '_' +
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
然而,我后来发现
属性
实际上是一个类,对它进行子类化非常适合。我在文档中找不到任何解释我需要重写什么的东西(以及\uuuu init\uuuu
等的参数签名),我也不想在C源代码中寻找它。有人知道我在哪里可以找到这些信息吗?这里有一个与property()中的代码相当的纯Python:
属性
是一个,因此您必须重写(或在新对象上重新实现)。为了便于参考,可以在此处找到C实现:@nneonneo:谢谢!第1228行的大注释块就是答案。如果你想写一个完整的答案,我会接受的。普尔索德你可以回答你自己的问题:)@BurhanKhalid,但尼诺值得称赞!这现在是在Python 3中的(由Raymond编写)。(它也在中。)
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__)