Python封装补充
property属性
property实际是setter getter deleter是集合体,并不是一个单独的方法
import math # 使用的库
class Circle:
def __init__(self,radius): #定义圆的半径
self.radius = radius
@property # area = property(area) #
def area(self):
return math.pi * self.radius**2 # 在类内部的函数,返回值
@property
def peirimeter(self):
return 2*math.pi*self.radius
c1= Circle(5) # 对类实例化 产生一个对象
print(c1.radius) # 打印的是半径的值
print(c1.area) # 这里相当于是直接使用了一个属性,并没有使用绑定方法
print(c1.peirimeter)
结果:
5
78.53981633974483
31.41592653589793
注意:
c.area是不能赋值的,虽然我们能够当做看似通过属性进行调用,实际是不是的
c1.area = 1
结果是:
AttributeError: can't set attribute
会抛出错误
下面是一个测试:
print(type(Circle.area)) #此时类是不能使用area函数的,结果是class property
print(Circle.area) # 结果是property object at 0x00000000006AB5E8
为什么要用property
将一个函数的类定义成property特性后,对象使用object.name,无法知道这个name是函数计算出来的,这种特性的使用方式遵循统一访问原则
面向对象中有三种类:
public --就是公开类
protected -- 父类
private -- 私有类
但是python的class机制并没有把这三种语法,像C++提供的是set和get方法,Python中是通过property方法提供
class People:
def __init__(self,name,SEX):
self.name = name
self.__sex = SEX # 进行封装
@property
def sex(self):
return self.__sex # 这里的返回值是真实的值
p1 = People('aaa','male')
print(p1.name) # 雷士通过属性的方式进行了调用
print(p1.sex)
结果:
male
aaa
通过属性的的方式是通过property的方式能够object.name的方式,这里就是用来实例化的p1.name p1.sex来是实现
但是这种属性并不是真正的属性,不能通过赋值的方式修改,后期需要进行修改用到了setter方法
setter方法是用了被property装饰器后的函数名命名了一个新的装饰器
class People:
def __init__(self,name,SEX):
self.name = name
self.__sex = SEX # 进行封装
@property
def sex(self):
return self.__sex # 这里的返回值是真实的值
@sex.setter # 想要对上面得函数属性进行修改
def sex(self,value): # value的值是是想要进行修改的参数
# print('============') # 测试用
print(self,value)
self.__sex = value # 真实的值是存在与__sex中,赋值给value
p1 = People('aaa','male') # 实例化
p1.sex = 'femele' # 这里就是通过类似赋值的方式进行了修改
print(p1.sex) # 新的查看
结果:
famele
上面的关键是@sex.setter重新命名了一个新的装饰器,装饰器的名字是sex,它的方法是setter。p1.sex = 'femele' 这这执行的时候首先从property下面的sex.__sex,这里存放的是真实的sex的值,所以的赋值只能在这里
通过抛出异常,限制输入的参数必须是字符串
class People:
def __init__(self,name,SEX):
self.name = name
# self.__sex = SEX # 进行封装
self.sex = SEX # 这里直接初始化的时候就会进入@sex.seter
@property
def sex(self):
return self.__sex # 这里的返回值是真实的值
@sex.setter # 想要对上面得函数属性进行修改
def sex(self,value): # value的值是是想要进行修改的参数
# print('============') # 测试用
print(self,value)
if not isinstance(value,str): # 判断修改的不是字符串,抛出异常
raise TypeError("male 必须是字符串类型")
self.__sex = value # 真实的值是存在与__sex中,赋值给value
p1 = People('aaa','male') # 实例化
p1.sex = 'femele'
print(p1.sex)
上面的修改是在setter中在修改赋值之前增加了异常处理,如果输入的不是字符串,就会抛出异常,但是这个只是在实例化赋值(p1.sex = 123)时候用才会抛出异常,在类的初始化的时候直接就self.sex=SEX,p1 = People('aaa',123) # 实例化最初的时候就会抛出异常
删除操作
class People:
def __init__(self,name,SEX):
self.name = name
# self.__sex = SEX # 进行封装
self.sex = SEX
@property
def sex(self):
return self.__sex # 这里的返回值是真实的值
@sex.setter # 想要对上面得函数属性进行修改
def sex(self,value): # value的值是是想要进行修改的参数
# print('============') # 测试用
print(self,value)
if not isinstance(value,str): # 判断修改的不是字符串,抛出异常
raise TypeError("male 必须是字符串类型")
self.__sex = value # 真实的值是存在与__sex中,赋值给value
@sex.deleter
def sex(self):
del self.__sex # 同样删除的是真实存放内容的__sex
p1 = People('aaa','male')
print(p1.sex)
del p1.sex # 删除p1的sex属性
Python封装补充的更多相关文章
- python 知识点补充
python 知识点补充 简明 python 教程 r 或 R 来指定一个 原始(Raw) 字符串 Python 是强(Strongly)面向对象的,因为所有的一切都是对象, 包括数字.字符串与 函数 ...
- python封装configparser模块获取conf.ini值(优化版)
昨天晚上封装了configparser模块,是根据keyname获取的value.python封装configparser模块获取conf.ini值 我原本是想通过config.ini文件中的sect ...
- 使用boost.python封装C++库
使用boost.python封装C++库 C++以高性能著称,但是编写较为复杂.而简洁是Python的强项.如果能珠联璧合,就能发挥两家之长.本文尝试用boost库的python模块封装C++ 前期准 ...
- PYTHON 100days学习笔记007-2:python数据类型补充(2)
目录 day007:python数据类型补充(2) 1.Python3 元组 1.1 访问元组 1.2 删除元组 1.3 元组运算符 1.4 元组索引,截取 1.5 元组内置函数 2.python3 ...
- PYTHON 100days学习笔记007-1:python数据类型补充(1)
目录 day007:python数据类型补充(1) 1.数字Number 1.1 Python 数字类型转换 1.2 Python 数字运算 1.3 数学函数 1.4 随机数函数 1.5 三角函数 1 ...
- 【AMAD】python-magic -- libmagic的python封装
简介 动机 作用 用法 个人评分 简介 libmagic的python封装 动机 封装libmagic,使用python代码获取文件类型. 作用 libmagic通过文件头部,来确定文件的类型. 用法 ...
- python 封装底层实现原理
事实上,python封装特性的实现纯属"投机取巧",之所以类对象无法直接调用私有方法和属性,是因为底层实现时,python偷偷改变了它们的名称. python在底层实现时,将它们的 ...
- Python封装应用程序的最佳项目结构是什么?
Python封装应用程序的最佳项目结构是什么? 转载来源于stackoverflow:https://stackoverflow.com/questions/193161/what-is-the-be ...
- python 封装、绑定
目录 python 封装.绑定 1.数据.方法的封装 2.隐藏属性 3.开放接口 4.绑定方法 1.对象的绑定 2.类的绑定(classmethod) 3.非绑定方法(staticmethod) 4. ...
随机推荐
- 数据库路由中间件MyCat - 源代码篇(11)
此文已由作者张镐薪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 4.配置模块 每个MyCatServer初始化时,会初始化: MyCatServer.java: publi ...
- 493. Reverse Pairs(BST, BIT, MergeSort)
Given an array nums, we call (i, j) an important reverse pair if i < j and nums[i] > 2*nums[j] ...
- [UE4]C++设置AnimInstance的相关问题
注意:ue4 4.17调用LoadObject<UAnimBlueprintGeneratedClass>直接崩 http://aigo.iteye.com/blog/2285001 UA ...
- 【转】mysql中set autocommit=0与start transaction的关系
在mysql中用户的任何一个更新操作(写操作)都被视为一个事务,set autocommit=0指事务非自动提交,自此句执行以后,每个SQL语句或者语句块所在的事务都需要显示"commit& ...
- IT兄弟连 Java语法教程 Java开发环境 JVM、JRE、JDK
要想开发Java程序,就需要知道什么是JVM.JRE以及JDK.JVM是运行Java程序的核心,JRE是支持Java程序运行的环境,而JDK是Java开发的核心,下面我们分别具体介绍它们以及它们之间的 ...
- python bbs项目代码分析
def index(request, *args, **kwargs): condition={} type_id = int(kwargs.get("type_id")) if ...
- github最火的springboot开源学习资料
https://github.com/JeffLi1993/springboot-learning-example https://github.com/ityouknow/spring-boot-e ...
- IOS 打包提示错误(ERROR ITMS-90125: ERROR ITMS-90087: ERROR ITMS-90209:)
提示这种错误是集成环信造成的,解决方法看环信的官方文档: 集成动态库上传AppStore 由于 iOS 编译的特殊性,为了方便开发者使用,我们将 i386 x86_64 armv7 arm64 几个平 ...
- css 文本溢出时显示省略号
.text-ellipsis { width:100px; height:60px; overflow: hidden;//隐藏滚动条 text-overflow:ellipsis; white-sp ...
- spring boot 事务
spring事务:默认自动提交只读:@Transactional(readOnly = true)读写:@Transactional(),因为等同于@Transactional(readOnly = ...