
Python 中 property() 函数及 @property 装饰器的使用
发布日期:2021-05-07 17:48:39
浏览次数:25
分类:精选文章
本文共 1933 字,大约阅读时间需要 6 分钟。
Python 中 property() 函数及 @property 装饰器的使用
文章目录
0. 参考资料
1. property 应用场景
- 在获取、设置和删除对象属性的时候,需要额外做一些工作。比如在游戏编程中,设置敌人死亡之后需要播放死亡动画。
- 需要限制对象属性的设置和获取。比如用户年龄为只读,或者在设置用户年龄的时候有范围限制。
- 这时就可以使用
property
工具,它把方法包装成属性,让方法可以以属性的形式被访问和调用。
2. property() 函数
- 语法:
property(fget=None, fset=None, fdel=None, doc=None) -> property attribute
- 说明:
fget
是获取属性值的方法。fset
是设置属性值的方法。fdel
是删除属性值的方法。doc
是属性描述信息。如果省略,会把fget
方法的docstring
拿来用(如果有的话)
- 示例代码:
class Student: def __init__(self): self._age = None def get_age(self): print('获取属性时执行的代码') return self._age def set_age(self, age): print('设置属性时执行的代码') self._age = age def del_age(self): print('删除属性时执行的代码') del self._age age = property(get_age, set_age, del_age, '学生年龄')student = Student()# 注意要用 类名.属性.__doc__ 的形式查看属性的文档字符串print('查看属性的文档字符串:' + Student.age.__doc__)"""查看属性的文档字符串:学生年龄"""# 设置属性student.age = 18"""设置属性时执行的代码"""# 获取属性print('学生年龄为:' + str(student.age))"""获取属性时执行的代码学生年龄为:18"""# 删除属性del student.age"""删除属性时执行的代码"""
3. @property 装饰器
@property
语法糖提供了比 property()
函数更简洁直观的写法。
- 被
@property
装饰的方法是获取属性值的方法,被装饰方法的名字会被用做属性名
。 - 被
@属性名.setter
装饰的方法是设置属性值的方法。 - 被
@属性名.deleter
装饰的方法是删除属性值的方法。
以下示例代码与使用 property()
函数版本的代码等价:
class Student: def __init__(self): self._age = None @property def age(self): print('获取属性时执行的代码') return self._age @age.setter def age(self, age): print('设置属性时执行的代码') self._age = age @age.deleter def age(self): print('删除属性时执行的代码') del self._agestudent = Student()# 设置属性student.age = 18"""设置属性时执行的代码"""# 获取属性print('学生年龄为:' + str(student.age))"""获取属性时执行的代码学生年龄为:18"""# 删除属性del student.age"""删除属性时执行的代码"""
4. 注意事项
- 可以省略设置属性值的方法,此时该属性变成只读属性。如果此时仍然设置属性,会抛出异常
AttributeError: can't set attribute
。 - 如果报错
RecursionError: maximum recursion depth exceeded while calling a Python object
,很可能是对象属性名和@property
装饰的方法名重名了,一般会在对象属性名前加一个下划线_
避免重名,并且表明这是一个受保护的属性。
完成于 20181113
发表评论
最新留言
感谢大佬
[***.8.128.20]2025年04月03日 14时06分11秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
2019CCPC女生专场赛_K - Tetris_打表/模拟_暴力之王
2019-03-05
服务器下载部署配置nginx,实现nginx代理多个项目
2019-03-05
算法笔记之快速幂
2019-03-05
P1125 [NOIP2008 提高组] 笨小猴 (Java)
2019-03-05
HDU1559(二维前缀和模板 Java&C++)
2019-03-05
ASP.NET javascript实现图片切换
2019-03-05
ASP.NET jQuery 小实例(实现图片的放大&缩小)
2019-03-05
IIS express web 无法启动服务器
2019-03-05
“/”应用程序中的服务器错误。
2019-03-05
MUI之ajax获取后台接口数据
2019-03-05
使用sqlserver 查询不连续的数据
2019-03-05
用div+css+html+js 实现图片放大
2019-03-05
mui+vue.js实现上拉刷新和下拉加载
2019-03-05
mui实现分享新浪微博、QQ分享、微信分享的申请过程和分享成功过程
2019-03-05
mui返回到父页页面并进行刷新
2019-03-05
数据库中优化lock
2019-03-05
layui 点击选择框为啥会出现震动(已解决)
2019-03-05