python @property装饰器

本文深入探讨了Python中@property装饰器的使用,展示了如何通过它实现对类属性的优雅拦截和参数检查,增强了面向对象编程的支持。同时,文章还讲解了类的保护属性和私有属性的概念,以及类方法和私有方法的定义方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

property可以优雅的对类的一个特定属性进行拦截,保证对参数进行必要的检查,更好的支持面向对象。

class Book(object):
    def __init__(self):
        self._price = None
 
    @property
    def price(self):
        return self._price 
 
    @price.setter
    def price(self, value):
    	if value > 999:
            raise ValueError("invalid price")
        self._price = value
 
    @price.deleter
    def price(self):
        del self._price 

if __name__ == '__main__':
    book = Book()
    book.price = 99 # 不报错
	book.price = 1234
	#Traceback (most recent call last):
  	#...
	#ValueError: invalid price
	

加上@property的getter方法就变成了属性,此时,@property本身又创建了另一个装饰器@x.setter,负责把一个setter方法变成属性赋值,这样就拥有一个可控的属性操作。
如果缺少因为缺少setter的函数方法,所以试图给price赋值时,会引发异常。

AttributeError: can't set attribute

优雅的写一个python类
类的保护属性 :
以单下划线开头,表示这是一个保护成员,只有类对象和子类对象自己能访问到这些变量。以单下划线开头的变量和函数被默认是内部函数,使用from module import *时不会被获取,但是使用import module可以获取。
类的私有属性:
__private_attrs:两个下划线开头,声明该属性为私有,不能在类的外部被使用或直接访问。在类内部的方法中使用时 self.__private_attrs。
类的方法:
在类的内部,使用 def 关键字来定义一个方法,与一般函数定义不同,类方法必须包含参数 self,且为第一个参数,self 代表的是类的实例。
类的私有方法:
__private_method:两个下划线开头,声明该方法为私有方法,只能在类的内部调用 ,不能在类的外部调用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值