python之--------封装

一、封装:

补充封装:

封装:
体现在两点:
1、数据的封装(将数据封装到对象中)
obj = Foo('宝宝',22)
2、封装方法和属性,将一类操作封装到一个类中
class Foo:
def __init__(self,name,age):
self.name = name
self.age = age
def show (self):
print(self.name,self.age)

什么是封装呢?(封装不是单纯意义的隐藏,其实它还是可以查看的)

  就是把一些不想让别人看的给隐藏起来了

封装数据:目的是保护隐私

功能封装:目的是隔离复杂度

如果用了私有的,在类的外部,无法直接使用变形的属性,但是在类的内部可以直接使用

 1.用我们常用的__init__方法里的self取值
class Course:#恰好给我们提供了实现这种思路的方法
# #一种思路,python
def __init__(self,price,period,name):
self.price = price
self.period = period
self.name = name
c = Course(2000,'linux','6 months')
print(c.period) 2.在类里面定义一个空字典,然后装在字典里面取值
def course(price,name ,period):
dic = {}
dic['price'] = price
dic ['name'] = name
dic ['period'] = period
return dic c = Course(2000,'python','6 months')
print(c.period) #对象名.属性名 查看属性的值 3.利用namedtuple方法
from collections import namedtuple #只有属性没有方法的类
Course = namedtuple('Course',['name','price','period']) #传两个参数,第一个为自定义的名字,第二个传进去的是属性
python = Course('python',10000,'6 moths') #相当于实例化了
print(python.name)

对象名.属性名取值的三种方法

2.封装类属性的私有属性(就是类属性前面加__)

 class Goods:
# 按照打八折计算 (定义了一个私有类属性)
__discount = 0.8 #变形后:_Goods__discount
def __init__(self,name,price):
self.name = name
self.price = price
def goods_price(self):
return self.price * Goods.__discount
apple = Goods('apple',10)
print(apple.goods_price())
# print(Goods.__dict__) #类名.__dict__
print(Goods._Goods__discount)

类属性1

 # 封装:把你不想让人看的隐藏起来
# 数据封装:目的保护隐私
class Teacher:
__School = 'oldboy' #类属性
def __init__(self,name,salary):
self.name = name
self .__salary = salary #_Teacher__salary
# 老师的属性 值
#怎么把薪水隐藏起来?
self.__salary=salary
def foo(self):
print('------') t=Teacher('egon',2000)
print(t.__dict__)
# print(t.name)
print(t._Teacher__salary)#让显示出来
print(Teacher._Teacher__School) #类属性使用_类名__属性名
t.foo()
#在本类内是可以正常调用的
#在本类外就必须以_类名__属性名调用(但是不建议你调)

类属性的私有方法

3.封装类对象的私有属性

成人的BMI数值:
过轻:低于18.5
正常:18.5-23.9
过重:24-27
肥胖:28-32
非常肥胖, 高于32
  体质指数(BMI)=体重(kg)÷身高^2(m)
  EX:70kg÷(1.75×1.75)=22.86

如上面的指标来计算下你自己的体质指数

 class Person:
def __init__(self,height,weight,name,sex):
self.__height = height #私有属性(让你不再外面调它)
# 在本类中可以调用,在类外就不可以调用了
self.__weigth = weight
self.__name = name
self.__sex = sex
def tell_bmi(self): #体重指数
return self.__weigth/self.__height ** 2 #在本类中可以调用 def tell_height(self):
print(self.__height)
def tell_weight(self): #告诉体重
return self.__weigth
def set_weigth(self,new_weight): #修改体重
if new_weight >20:
self.__weigth = new_weight
else:
raise TypeError('你也太瘦了,瘦的连斤数都(快)没了') #如果体重小于20或者负的,就主动提示一个报错
egg = Person(1.6,96,'haiyan','female')
print(egg.tell_bmi())
# egg.__height #在类外不能调用
# print(egg._Person__height) #在类外查看得这样调用
print(egg.__dict__) #查看变形后的类型
# egg.set_weigth(-10)
# print(egg.tell_weigth())
egg.set_weigth(66) #修改体重为66
print(egg.tell_weight())

计算体质指数,衡量人健康的标准(对象的私有属性一)

 class People:
def __init__(self,name,age,sex,height):
self.__name = name
self.__age = age
self.__sex = sex
self.__height = height def tell_name(self): #看人名字
print(self.name)
def set_name(self,val): #修改名字
if not isinstance(val, str):
raise TypeError('名字必须是字符串类型')
self.__name = val
def tell_info(self):
print('''
---------%s info-----------
name:%s
age:%s
sex:%s
height:%s'''%(self.__name,self.__name,self.__age,self.__sex,self.__height)) p=People('egon',21,'male','')
p.tell_info()
p.set_name('haiyan') #调用修改名字的方法
p.tell_info()
# print(p._People__name)#就可以看到了

对象属性的私有属性二

4.封装类方法的私有属性

 # 方法的私有属性
class Parent:
def __init__(self):
self.__func() #__func==_Parent__func
def __func(self):
print('Parent func') class Son(Parent):
def __init__(self):
self.__func() #_Son__func
def __func(self):
print('Son func') def _Parent__func(self):
print('son _Parent__func')
s = Son()
print(Parent.__dict__) #类名.__dict__查看变形后的结果 # 私有属性:在本类内是可以正常调用的
# 在本类外就必须以_类名__属性名调用(但是不建议你调)

类方法的私有属性1

 class Foo:
def __func(self):
print('from foo')
class Bar(Foo):
def __func(self):
print('from bar')
b = Bar()
b._Foo__func()
b._Bar__func()

方法的私有属性2

 class Foo:
def __init__(self,height,weight):
self.height = height
self.weight = weight
def __heightpow(self): #私有方法
return self.height * self.height
def tell_bmi(self):
return self.weight/self.__heightpow() egon = Foo(1.7,120)
print(egon.tell_bmi())
print(Foo.__dict__)
print(egon._Foo__heightpow()) #虽说是私有的,但是还是可以查看的

装饰方法的私有属性3

5.property

为什么要用property:将一个类的函数定义成特性以后,对象再去使用的时候obj.name,根本无法察觉自己的name是执行了一个函数然后计算出来的,这种特性的使用方式遵循了统一访问的原则

1.计算圆的面积和周长

 from math import pi
class Circle:
def __init__(self,radius):
self.radius = radius
@property #装饰器:把一个方法当成一个属性用了
def area(self):
return self.radius * self.radius* pi
@property
def peimeter(self):
return 2*pi*self.radius c = Circle(10)
print(c.area) #当成一个属性来调了,就不用加括号了
print(c.peimeter)

property

2.缓存网页信息

 from urllib.request import urlopen
class Web_page:
def __init__(self,url):
self.url = url
self.__content = None #内容设置为None
@property
def content(self):
if self.__content: #如果不为空,就说明已经下载了 _Web_page__content
return self.__content
else:
self.__content = urlopen(self.url).read()#做缓存
return self.__content
mypage = Web_page('http://www.baidu.com')
print(mypage.content)
print(mypage.content)
print(mypage.content)

property(2)

3.求和,平均值,最大值,最小值

 class Num:
def __init__(self,*args):
print(args)
if len(args)==1 and (type(args[0]) is list or type(args[0]) is tuple):
self.numbers=args[0]
else:
self.numbers = args @property
def sum(self):
return sum(self.numbers) @property
def avg(self):
return self.sum/len(self.numbers) @property
def min(self):
return min(self.numbers) @property
def max(self):
return max(self.numbers)
num = Num([3,1,3])
vvv = Num(8,2,3)
print(num.sum)
print(num.min)
print(num.avg)
print(num.max)
print('-----------')
print(vvv.sum)
print(vvv.min)
print(vvv.avg)
print(vvv.max)

property(3)

6.setter

 class Goods:
__discount = 0.8 #类的私有属性
def __init__(self,name,price):
self.name = name
self.__price = price @property
def price(self):
# if hasattr(self,'__price'):
return self.__price * Goods.__discount
# else:
# raise NameError @price.setter
def price(self,new_price):
if type(new_price) is int:
self.__price = new_price @price.deleter
def price(self):
del self.__price apple = Goods('apple',10)
# print(apple.price)
apple.price = 20
print(apple.price) # del apple.price
# print(apple.price)
# apple.set_price(20)
# apple._Goods__apple

买东西

@property把一个类中的方法 伪装成属性
原来是obj.func()
现在是obj.func -->属性
1.因为属性不能被修改
所以用了@funcname.setter
obj.func = new_value 调用的是被@funcname.setter装饰器装饰的方法
被@property装饰的方法名必须和被@funcname.setter装饰的方法同名
2.也可以另一种方法修改,但是上一种方法吧一个类中的方法伪装成属性来调用了,而这种方法
还是原来实例化一样调用
例如:
 class People:
def __init__(self,name,age,sex,height):
self.__name = name
self.__age = age
self.__sex = sex
self.__height = height def tell_name(self): #看人名字
print(self.name)
def set_name(self,val): #修改名字
if not isinstance(val, str):
raise TypeError('名字必须是字符串类型')
self.__name = val
def tell_info(self):
print('''
---------%s info-----------
name:%s
age:%s
sex:%s
height:%s'''%(self.__name,self.__name,self.__age,self.__sex,self.__height)) p=People('egon',21,'male','')
p.tell_info()
p.set_name('haiyan') #调用修改名字的方法
p.tell_info()
# print(p._People__name)#就可以看到了

 
 
 
 
 
 
 
 
 

【第8篇】:Python之面向对象的更多相关文章

  1. Python开发【第七篇】:面向对象

    Python之路[第五篇]:面向对象及相关   面向对象基础 基础内容介绍详见一下两篇博文: 面向对象初级篇 面向对象进阶篇 其他相关 一.isinstance(obj, cls) 检查是否obj是否 ...

  2. Python之路【第五篇】:面向对象及相关

    Python之路[第五篇]:面向对象及相关   面向对象基础 基础内容介绍详见一下两篇博文: 面向对象初级篇 面向对象进阶篇 其他相关 一.isinstance(obj, cls) 检查是否obj是否 ...

  3. Python之路【第五篇】:面向对象和相关

    Python之路[第五篇]:面向对象及相关   面向对象基础 基础内容介绍详见一下两篇博文: 面向对象初级篇 面向对象进阶篇 其他相关 一.isinstance(obj, cls) 检查是否obj是否 ...

  4. Python开发【第七篇】:面向对象 和 python面向对象进阶篇(下)

    Python开发[第七篇]:面向对象   详见:<Python之路[第五篇]:面向对象及相关> python 面向对象(进阶篇)   上一篇<Python 面向对象(初级篇)> ...

  5. 【Python之路】第七篇--Python基础之面向对象及相关

    面向对象基础 基础内容介绍详见一下两篇博文: 面向对象初级篇 面向对象进阶篇 其他相关 一.isinstance(obj, cls) 检查obj是否是类 cls 的对象 class Foo(objec ...

  6. Python学习【第五篇】:面向对象及相关

    面向对象基础 基础内容介绍详见一下两篇博文: 面向对象初级篇 面向对象进阶篇 其他相关 一.isinstance(obj, cls) 检查是否obj是否是类 cls 的对象 1 2 3 4 5 6 c ...

  7. Python之路【第五篇】:面向对象编程

    面向对象编程思维导向图

  8. Python 第六篇(上):面向对象编程初级篇

    面向:过程.函数.对象: 面向过程:根据业务逻辑从上到下写垒代码! 面向过程的编程弊:每次调用的时候都的重写,代码特别长,代码重用性没有,每次增加新功能所有的代码都的修改!那有什么办法解决上面出现的弊 ...

  9. Python之面向对象与类

    本节内容 面向对象的概念 类的封装 类的继承 类的多态 静态方法.类方法 和 属性方法 类的特殊成员方法 子类属性查找顺序 一.面向对象的概念 1. "面向对象(OOP)"是什么? ...

  10. 【转】Python之面向对象与类

    [转]Python之面向对象与类 本节内容 面向对象的概念 类的封装 类的继承 类的多态 静态方法.类方法 和 属性方法 类的特殊成员方法 继承层级关系中子类的实例对象对属性的查找顺序问题 一.面向对 ...

随机推荐

  1. python基础练习-猜年龄、编写登陆接口小程序

    python基础练习:   一.猜年龄 , 可以让用户最多猜三次! age=40 count = 1 while count <=3 : user_guess=int(input("i ...

  2. Xcode9自带版本控制系统(Git)的使用

    情形一:新项目工程 前提是首先你得有个Github账号. 1.创建新工程,选中使用git,创建本地仓库. 2.在偏好设置添加git账号. 3.创建Github远程仓库,xcode会自动帮你在Githu ...

  3. Linux I2C设备驱动编写(一)【转】

    本文转载自:http://blog.csdn.net/airk000/article/details/21345457 在Linux驱动中I2C系统中主要包含以下几个成员: I2C adapter 即 ...

  4. 【Codevs1288】埃及分数

    Position: http://codevs.cn/problem/1288/ Description 在古埃及,人们使用单位分数的和(形如1/a的, a是自然数)表示一切有理数. 如:2/3=1/ ...

  5. 【Angular】过滤器

    AngularJS学习笔记 {{ name | uppercase}} {{ 123.456789 | number:2 }} app.controller('DemoController', ['$ ...

  6. 开发PL/SQL子程序和包及使用PL/SQL编写触发器、在JDBC中应用Oracle

    1.  子程序的各个部分: 声明部分.可执行部分.异常处理部分(可选) 2.子程序的分类: A.  过程 - 执行某些操作 a.  创建过程的语法: CREATE [OR REPLACE]  PROC ...

  7. Mysql 数据库编码问题

    数据库建表后,插入数据,如果数据位汉子,将提示错误:“incorrect string value....”. 解决方法:改变数据库编码 第一种方法:改变database 编码: alter data ...

  8. [Swift通天遁地]七、数据与安全-(13)单元测试的各个状态和应用

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  9. Java线程之Synchronized用法

    synchronized是Java中的关键字,是一种同步锁.它修饰的对象有以下几种: 修饰一个代码块,被修饰的代码块称为同步语句块,其作用的范围是大括号{}括起来的代码,作用的对象是调用这个代码块的对 ...

  10. leetCode----day02---- 买卖股票的最佳时机 II

    要求: 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意:你不能同时参与多笔交易(你必 ...