不使用setter的Python覆盖getter

不使用setter的Python覆盖getter,第1张

不使用setter的Python覆盖getter

使用

.getter
原始属性的装饰器:

class superhuman(human):    @human.name.getter    def name(self):        return 'super ' + self._name

请注意,您必须使用全名才能到达父类上的原始属性描述符。

示范:

>>> class superhuman(human):...     @human.name.getter...     def name(self):...         return 'super ' + self._name... >>> s = superhuman('john')>>> print s.namesuper john>>> s.name = 'jack'>>> print s.namesuper jack

property
描述对象就是 一个
对象,尽管它可以有多个与之相关的方法(吸气,setter和删除器)。现有描述符提供的
.getter
.setter
.deleter
装饰器函数将
property
返回描述符本身的副本,并替换该特定方法。

因此,在

human
基类中发生的情况是,首先使用装饰器 创建
了描述符
@property
,然后用
@name.setter
语法同时具有getter和setter的描述符替换了该描述符。之所以可行,是因为python装饰器用相同的名称替换了原始装饰函数,它基本上会执行
name=name.setter(name)
。请参见@property装饰器如何工作?有关所有工作原理的详细信息。

在您的子类中,您只需使用该技巧即可创建描述符的新副本,而只需替换getter。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5643913.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存