python中@property、@setter和@deleter

上一次我给大家讲解了装饰器,它能让函数在不做更多变动的情况下增加某些额外的功能

而今天我们来了解一下python中几个内置的装饰器

通常我们写代码的时候,都不希望外部代码能够轻易地修改内部属性的参数

因为要在外部改变参数的时候,我们必须想办法通过内部函数去检验参数的正确性,以确保设置正确

但是我们不让外部轻易地修改数据,反过来我们自己也不能很方便地从外部获取数据

那么,怎么样才能既在外部轻易地修改数据,又能很方便地获取到数据呢??

下面请看代码:

class Student():

  def __init__(self):            # 初始化
    self._score = None

  def get_score(self):           # 获得成绩
    return self._score

  def set_score(self, value):    # 设置成绩,并判断是否符合要求
    if value < 0 or value > 100:
      raise ValueError(‘score must between 0 ~ 100!‘)
    self._score = value

if __name__ == "__main__":  s = Student()

_score(单“_”)完全可以看成是一个私有变量名,因为在模块与类外无法调用它

在这程序里我们不管设置成绩或者获取成绩,都得用最傻的办法,当然,我们也不能设置不合理的成绩值

如下图:

 python中@property、@setter和@deleter

我们如果想直接把score绑定为Student的一个属性,方便来调用和赋值的话,就得这么修改:class Student():

  def __init__(self):
    self._score = None

  def get_score(self):
    return self._score

  def set_score(self, value):
    if value < 0 or value > 100:
      raise ValueError(‘score must between 0 ~ 100!‘)
      self._score = value

  score = property(get_score, set_score)         # 将方法变为属性

if __name__ == "__main__":
  s = Student()

这时,我们确实可以操作s.score来操作内部的数据了

python中@property、@setter和@deleter

其实我们还有另外一种更好的办法,就是把一个getter变为@property,而@property本身又创建了另一个装饰器,这里是@score.setter,这样getter、setter方法都变为属性可以赋值调用了

(getter意为获得者,这里指get_score;setter意为设置者,这里指set_score)

修改后的代码如下:

class Student():

  def __init__(self):
    self._score = None

  @property
  def score(self):
    return self._score

  @score.setter
  def score(self, value):
    if value < 0 or value > 100:
      raise ValueError(‘score must between 0 ~ 100!‘)
      self._score = value

if __name__ == "__main__":
  s = Student()

这个程序里就不用特意写get_score和set_score了,@property已经分配好了,所以我们两个函数都可以叫score

这样我们就可以只通过s.score来方便地操作数据了,当然我们依旧不能取范围以外的值

 python中@property、@setter和@deleter

最后我们再看@deleter,只要再写一个如下的函数,我们就可以通过del s.score来轻松删掉原来的值了

@score.deleter
def score(self):
    del self._score

最后我们总结一下:

@property定义只读属性,@setter定义可读可写属性,@deleter定义可读可写可删除属性

相关推荐