如何通过Python的@property、@x.setter和@x.deleter实现属性封装?

2026-05-26 11:351阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计443个文字,预计阅读时间需要2分钟。

如何通过Python的@property、@x.setter和@x.deleter实现属性封装?

`@property` 可以将 Python 定义的函数作为 属性 使用,以便于访问。这提供了更友好的访问方式,但有时也需要使用 setter 或 deleter。只有 `@property` 表示只读访问。同时有 `@property` 和 `@x.setter` 表示可读可写。

@property可以将python定义的函数“当做”属性访问,从而提供更加友好访问方式,但是有时候setter/deleter也是需要的。

  • 只有@property表示只读。
  • 同时有@property和@x.setter表示可读可写。
  • 同时有@property和@x.setter和@x.deleter表示可读可写可删除。

代码如下

class student(object): #新式类 def __init__(self,id): self.__id=id @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 and 100') self._score=value @property #读(只能读,不能写) def get_id(self): return self.__id s=student('123456') s.score=60 #写 print s.score #读 #s.score=-2 #ValueError: score must between 0 and 100 #s.score=32.6 #ValueError: score must be an integer! s.score=100 #写 print s.score #读 print s.get_id #读(只能读,不可写) #s.get_id=456 #只能读,不可写:AttributeError: can't set attribute

运行结果:

60
100
123456

代码

class A(object):#要求继承object def __init__(self): self.__name=None #下面开始定义属性,3个函数的名字要一样! @property #读 def name(self): return self.__name @name.setter #写 def name(self,value): self.__name=value @name.deleter #删除 def name(self): del self.__name a=A() print a.name #读 a.name='python' #写 print a.name #读 del a.name #删除 #print a.name # a.name已经被删除 AttributeError: 'A' object has no attribute '_A__name'

结果

None

如何通过Python的@property、@x.setter和@x.deleter实现属性封装?

python

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计443个文字,预计阅读时间需要2分钟。

如何通过Python的@property、@x.setter和@x.deleter实现属性封装?

`@property` 可以将 Python 定义的函数作为 属性 使用,以便于访问。这提供了更友好的访问方式,但有时也需要使用 setter 或 deleter。只有 `@property` 表示只读访问。同时有 `@property` 和 `@x.setter` 表示可读可写。

@property可以将python定义的函数“当做”属性访问,从而提供更加友好访问方式,但是有时候setter/deleter也是需要的。

  • 只有@property表示只读。
  • 同时有@property和@x.setter表示可读可写。
  • 同时有@property和@x.setter和@x.deleter表示可读可写可删除。

代码如下

class student(object): #新式类 def __init__(self,id): self.__id=id @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 and 100') self._score=value @property #读(只能读,不能写) def get_id(self): return self.__id s=student('123456') s.score=60 #写 print s.score #读 #s.score=-2 #ValueError: score must between 0 and 100 #s.score=32.6 #ValueError: score must be an integer! s.score=100 #写 print s.score #读 print s.get_id #读(只能读,不可写) #s.get_id=456 #只能读,不可写:AttributeError: can't set attribute

运行结果:

60
100
123456

代码

class A(object):#要求继承object def __init__(self): self.__name=None #下面开始定义属性,3个函数的名字要一样! @property #读 def name(self): return self.__name @name.setter #写 def name(self,value): self.__name=value @name.deleter #删除 def name(self): del self.__name a=A() print a.name #读 a.name='python' #写 print a.name #读 del a.name #删除 #print a.name # a.name已经被删除 AttributeError: 'A' object has no attribute '_A__name'

结果

None

如何通过Python的@property、@x.setter和@x.deleter实现属性封装?

python

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。