@property
对于类的方法,装饰器一样起作用。Python内置的@property装饰器就是负责把一个方法变成属性调用的:
class Student(object):
def get_score(self):
return self._score
def set_score(self, value):
if not isinstance(value, int):
raise ValueError('score must be an integer!')
if value < 0 or value > 100:
raise ValueError('score must between 0 ~ 100!')
self._score = value
可以使用@property使得方法能像函数的属性一样调用。如果只是设置@property 而没有设置@score.setter则只是可读,而不可写
class Student(object):
def __init__(self,score):
self.score=score
@property
def score(self):
return self._score
@score.setter
def score(self, value):
if not isinstance(value, int):
raise ValueError('score must be an integer!')
if value < 0 or value > 100:
raise ValueError('score must between 0 ~ 100!')
self._score = value
@score.deleter
def score(self):
raise AttributeError("can't delete attribute")
__slots__
# encoding:utf-8
class student(object):
pass
# 可以给类动态添加属性
xiao=student()
xiao.name='weiyudang'
print xiao.name
##也可以动态的添加方法
from types import MethodType
def set_age(self,age):
self.age=age
xiao.set_age=MethodType(set_age,xiao,student) ##给实例绑定的方法,不能应用于其他的实例
xiao.set_age(25)
def set_sex(self,sex):
self.age=sex
student.set_sex=MethodType(set_age,None,student) #给类绑定的方法
li=student()
li.set_sex('male')
##通常情况下,上面的set_score方法可以直接定义在class中,但动态绑定允许我们在程序运行的过程中动态给class加上功能,这在静态语言中很难实现
'''但是,如果我们想要限制class的属性怎么办?比如,只允许对Student实例添加name和age属性。
为了达到限制的目的,Python允许在定义class的时候,定义一个特殊的__slots__变量,来限制该class能添加的属性:'''
class Student(object):
__slots__=('name','age')
July=Student()
July.score=15
Traceback (most recent call last):
File "D:/dec.py", line 39, in <module>
July.score=15
AttributeError: 'Student' object has no attribute 'score'
使用__slots__要注意,__slots__定义的属性仅对当前类起作用,对继承的子类是不起作用的: