装饰器(decorator)可以给函数动态加上功能,对于类的方法,装饰器一样起作用。
Python内置的@property装饰器就是负责把一个方法变成属性调用。
@property的实现比较复杂,我们先考察如何使用。把一个getter方法变成属性,只需要加上@property就可以了,
此时,@property本身又创建了另一个装饰器@birth.setter,负责把一个setter方法变成属性赋值,就有一个可控的属性操作
# *===================================*
# -*- coding: utf-8 -*-
# * Time : 2019-06-27 17:52
# * Author : zhangsf
# *===================================*
class Person(object):
@property # 将birth 转换为属性,外部可是直接s.birth访问
def birth(self):
return self._birth
@birth.setter # @property本身又创建了另一个装饰器@score.setter,负责把一个setter方法变成属性赋值
def birth(self, value):
if value > 0 and value < 100:
self._birth = value
else:
raise ValueError('birth must between 0~100')
@property # 将age方法转换为属性,外部调用时,可以用s.age访问。
def age(self):
return 2015 - self._birth
# 没有使用property装饰器的时候,直接当做属性调用的时候是返回对象方法,需要以方法调用
def heith(self):
return 2015 - self._birth
s = Person()
s.birth = 10
print(s.birth)
# print(s.birth())
print(s.age)
# print(s.age())
print(s.heith)
print(s.heith())
结果:
10
2005
<bound method Person.heith of <__main__.Person object at 0x10e00a240>>
2005
上面的birth是可读写属性有setter方法,而age就是一个只读属性,没有setter,因为age可以根据birth和当前时间计算出来。

本文深入探讨了Python中@property装饰器的使用方法,通过实例展示了如何将方法转换为属性进行读取和设置,同时介绍了其在类方法中的应用,使读者能够掌握@property装饰器的基本原理和实践技巧。

被折叠的 条评论
为什么被折叠?



