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封装补充的更多相关文章

  1. python 知识点补充

    python 知识点补充 简明 python 教程 r 或 R 来指定一个 原始(Raw) 字符串 Python 是强(Strongly)面向对象的,因为所有的一切都是对象, 包括数字.字符串与 函数 ...

  2. python封装configparser模块获取conf.ini值(优化版)

    昨天晚上封装了configparser模块,是根据keyname获取的value.python封装configparser模块获取conf.ini值 我原本是想通过config.ini文件中的sect ...

  3. 使用boost.python封装C++库

    使用boost.python封装C++库 C++以高性能著称,但是编写较为复杂.而简洁是Python的强项.如果能珠联璧合,就能发挥两家之长.本文尝试用boost库的python模块封装C++ 前期准 ...

  4. PYTHON 100days学习笔记007-2:python数据类型补充(2)

    目录 day007:python数据类型补充(2) 1.Python3 元组 1.1 访问元组 1.2 删除元组 1.3 元组运算符 1.4 元组索引,截取 1.5 元组内置函数 2.python3 ...

  5. PYTHON 100days学习笔记007-1:python数据类型补充(1)

    目录 day007:python数据类型补充(1) 1.数字Number 1.1 Python 数字类型转换 1.2 Python 数字运算 1.3 数学函数 1.4 随机数函数 1.5 三角函数 1 ...

  6. 【AMAD】python-magic -- libmagic的python封装

    简介 动机 作用 用法 个人评分 简介 libmagic的python封装 动机 封装libmagic,使用python代码获取文件类型. 作用 libmagic通过文件头部,来确定文件的类型. 用法 ...

  7. python 封装底层实现原理

    事实上,python封装特性的实现纯属"投机取巧",之所以类对象无法直接调用私有方法和属性,是因为底层实现时,python偷偷改变了它们的名称. python在底层实现时,将它们的 ...

  8. Python封装应用程序的最佳项目结构是什么?

    Python封装应用程序的最佳项目结构是什么? 转载来源于stackoverflow:https://stackoverflow.com/questions/193161/what-is-the-be ...

  9. python 封装、绑定

    目录 python 封装.绑定 1.数据.方法的封装 2.隐藏属性 3.开放接口 4.绑定方法 1.对象的绑定 2.类的绑定(classmethod) 3.非绑定方法(staticmethod) 4. ...

随机推荐

  1. JavaScript巩固篇(一)——数据类型与全局变量、局部变量、垃圾回收机制、存储方式、生命周期

    知识要点 数据类型 存储方式 全局变量与局部变量 变量的生命周期 垃圾回收机制 知识概览 数据类型 JavaScript的数据类型分为:基本类型.引用类型 本质区别: 基本数据类型的变量实际值存储在栈 ...

  2. ColorMask与Blend

    Shader "N/T" { Properties { _Color ("Texture to blend", Color) = (1,1,1,1) } Sub ...

  3. JavaScript 与 CSS 滚动实现最新指南

    一些(网站)滚动的效果是如此令人着迷但你却不知该如何实现,本文将为你揭开它们的神秘面纱.我们将基于最新的技术与规范为你介绍最新的 JavaScript 与 CSS 特性,(当你付诸实践时)将使你的页面 ...

  4. input accept属性控制选择文件类型

    <form> <input type="file" name="pic" id="pic" accept="im ...

  5. Luogu P1155 双栈排序 图论?模拟吧。。

    今天想做做图论,于是点开了这道题....(是二分图染色然而我没看出来) 四种操作及条件: 1. s1.push() 需满足 待push的元素小于栈顶 && { 若在原序列中,待push ...

  6. Codeforces Round #566 (Div. 2) B. Plus from Picture

    链接: https://codeforces.com/contest/1182/problem/B 题意: You have a given picture with size w×h. Determ ...

  7. es6新语法系列,查找字符串,模板字符串

    一.模板字符串: ES6引入了一种新型的字符串字面量语法,我们称之为模板字符串(template strings).除了使用反撇号字符 ` 代替普通字符串的引号 ' 或 " 外,它们看起来与 ...

  8. Zookeeper+websocket实现对分布式服务器的实时监控(附源码下载)

    ​ 我就是个封面 Zookeeper简介 Zookeeper是Hadoop的一个子项目,它是分布式系统中的协调系统. 简单来说就是一个Zookeeper注册同步中心,内部结构为一个树形目录,每个节点上 ...

  9. unity3d + photon + grpc + nodejs + postgis/postgresql 游戏服务器设计

    unity3d + photon + grpc + nodejs + postgis/postgresql 游戏服务器设计 最近做玩票性质的游戏项目,客户端技术是 unity3d 和 android. ...

  10. webpack.config.js====entry入口文件的配置

    1.  一般是采用对象语法: entry: { index: './src/default/js/index.js' }, https://webpack.css88.com/concepts/ent ...