Python装饰器中@property使用详解
最初的声明方式
在没有@property修饰的情况下,需要分别声明get、set、delete函数,然后初始化property类,将这些方法加载进property中
class C持有property的实例化对象x
对外表现出来C().x时,实际上是调用C()中的x(property类)中设置的fset,fget,fdel,分别对应getx,setx,delx
C真正持有的x,是self._x被隐藏起来了
class C(object): def getx(self): return self._x def setx(self, value): self._x = value def delx(self): del self._x x = property(getx, setx, delx, "I'm the 'x' property.")
property类 结合x = property(getx, setx, delx, "I'm the 'x' property.")
与property的__init__()
可以发现property接受四个参数
fget,用于获取属性值,
fset,用于设置属性值
fdel,用于删除属性
doc,属性的介绍
可以单独设置fget、fset、fdel…
x = property,x.getter(getx),x.setter(setx),x.deleter(delx)
class property(object): def deleter(self, *args, **kwargs): # real signature unknown """ Descriptor to change the deleter on a property. """ pass def getter(self, *args, **kwargs): # real signature unknown """ Descriptor to change the getter on a property. """ pass def setter(self, *args, **kwargs): # real signature unknown """ Descriptor to change the setter on a property. """ pass def __delete__(self, *args, **kwargs): # real signature unknown """ Delete an attribute of instance. """ pass def __getattribute__(self, *args, **kwargs): # real signature unknown """ Return getattr(self, name). """ pass def __get__(self, *args, **kwargs): # real signature unknown """ Return an attribute of instance, which is of type owner. """ pass def __init__(self, fget=None, fset=None, fdel=None, doc=None): # known special case of pass
使用装饰器的声明方式
需要注意,装饰器只是一个python的语法糖,可以拆解成普通使用方法,如property(getx)
@property
创建了一个实例x,对于def x(self)
实际上是C类持有x = property(fget=x)
因此,x.setter
方法指向的是property.setter
,也是起到装饰器效果x.setter(x)
(注意,前者x是property实例x,后者x是def x(self, value)
函数),x.deleter
同理
class C(object): @property def x(self): "I am the 'x' property." return self._x @x.setter def x(self, value): self._x = value @x.deleter def x(self): del self._x
为什么property实例化后的名字与属性名一致?
换种问法就是为什么x = property(...)
可以认为是
attributes_and_methods = { x.__name__: property(x), //声明C类持有property实例 #... } C = type('C', (object,), attributes_and_methods)
使用装饰器的调用过程
执行C().x时,调用的是C().x(property)绑定的fget方法,用过__get__
唤醒,setter、deleter同理
class property(object): #... def __init__(self, fget=None, fset=None, fdel=None, doc=None): self.fget = fget self.fset = fset self.fdel = fdel ... def __get__(self, obj, objtype=None): # real signature unknown if obj is None: return self if self.fget is None: raise AttributeError("unreadable attribute") return self.fget(obj)
总结
到此这篇关于Python装饰器中@property使用详解的文章就介绍到这了,更多相关Python饰器@property内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
- 掌握Python property装饰器巧妙管理类的属性
- python装饰器中@property属性的使用解析
- Python中通过property设置类属性的访问
- 关于python中@property的使用方法
- Python property装饰器使用案例介绍
- Python深入分析@property装饰器的应用
- python 中的@property的用法详解
- python中@Property属性使用方法
- Python中property属性的用处详解
- Python中关于property使用的小技巧
- Python的@property的使用
- 详解Python装饰器之@property
- Python property函数的具体使用
相关文章
windows下安装Python的XlsxWriter模块方法
今天小编就为大家分享一篇windows下安装Python的XlsxWriter模块方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-05-05Python3实现爬取简书首页文章标题和文章链接的方法【测试可用】
这篇文章主要介绍了Python3实现爬取简书首页文章标题和文章链接的方法,结合实例形式分析了Python3基于urllib及bs4库针对简书网进行文章抓取相关操作技巧,需要的朋友可以参考下2018-12-12
最新评论