一、复习: 1、面向过程与面向对象 过程:程序流程化,可拓展性差 对象:程序流程多样化,可拓展性强 面向对象引入属性 | 方法的概念,通过所属者.语法调用 2、拥有名称空间的对象:有__dict__属性,该属性就是指向对象的名称空间 文件 | 包(__init__.py文件)| 函数 | 类 可以为__dict__属性添加值,简化为.语法,也可以对__dict__整体赋值一个字典 3、类与对象 类是抽象的,不是真实存在的:具有相同相同特征(属性)和行为(方法)个体的集合的抽象 对象具象的,是真实存在的:具有特征与行为的实际个体(类的实际体现:实例化) 4、类与对象的语法: class 类名: 代码块(一堆属性与方法) 对象名 = 类名() 5、类会随所属文件加载而加载(执行内部所有代码),形成类的名称空间 每个实例化出来的对象及类都有自己的名称空间 类与对象都可以通过.语法来拓展新功能 提前在类中属性的属性与方法,在对象一产生就可以使用这些属性和方法 对象查找属性的顺序:先找自身,如果没有找类的(只有访问权没有修改权) 二、对象的特有名称空间 __init__方法会在实例化对象时被调用 1、会为实例化的对象形成空的名称空间 2、__init__就是一个方法,可以被传参,在类名(实参)这种方式下调用并传参__init__(self,形参) 3、第一个self就是要产生的当前对象 重点:在方法内部,形参拿到了实参值,利用self.属性名 = 形参 = 实参值,对对象的名称空间添加属性(即初始化对象的名称空间) 类中方法第一个默认参数一定是调用该方法的对象 三、类方法:类中@classmethod修饰的方法 class Tool: @classmethod def add(cls,n1,n2): cls.text() return n1 + n2 @classmethod def text(cls): pass print(Tool.add(10,20)) #如果不加装饰器,类要调用的话 Tool.add(Tool,10,20) print(tool.add(100,200)) 总结:类的名字、对象都可以使用,但是出现了类与对象使用时,参数个数不一致 对象调用时,外界传入两个参数,内部接受到三个,第一个是对象本身 所以类方法就是被类与对象调用时,第一个参数一定是类,不建议拿对象来调用 四、属性与方法的总结 class OldBoy: #属于类的属性 name = '老男孩' #属于对象的属性 def __init__(self,name): self.name #属于类的方法 #需求:获取机构的名字 @classmethod def get_class_name(cls): return cls.name #属于对象的方法 #需求:获取校区的名字 def get_school_name(self): return self.name #创建校区 shanghai = OldBoy('上海校区') shenzhen = OldBoy('深圳校区') #类方法的使用 print(OldBoy.get_class_name()) #对象方法的使用(类调用对象方法,必须要把操作的对象手动传入,不建议使用) print(shanghai.get_school_name()) 五、封装 1、类的属性与方法封装 封装:对外隐藏类中一些属性与方法的实现细节 优点:外界不能直接访问,让内部的属性与方法具有安全保障 class A: #__开头的属性,在外界不能通过cord | __cord 直接访问,对外隐藏了 __cord = '01012300' #__开头的方法,在外界不能通过 get_money | __get_money 直接访问 @classmethod def __get_money(cls) print('输入密码') #内部还是还是可以直接访问__开头的属性与方法 @classmethod def test(cls,flag): #在调用test与访问具体数据与功能间添加安全处理的操作 if flag == '自家人' #(安全处理的判断) print(__cord) cls.__get_money A.test('自家人') 封装的原理:把用__开头的名字更名为_类名__变量名,所以外界也可以直接通过_类名__变量名访问到(不知道的就会以为访问不到) 2、对象的属性与方法封装 原理与类的属性与方法封装一样 class AAA: def __init__(self,money): self.__money = money self.__id = 1000 @property def id(self): return self.__id @id.setter def id(self,id): self.__id = id 对象属性的封装: 对象的属性值一般都来源于外界,外界是有权利再次访问的 封装的目的不是让外界无法访问,而是不让其直接访问,可以在完成安全处理后再访问 如何做到外界还是通过变量名来对属性进行取值赋值,但是走的方法是间接拿到的值 __money被封装,外界还是可以通过 对象.money 取值赋值 #取值 @property #在外界可以 对象.money 进行取值 def money(self): return self.__money #赋值 @money.setter #在外界可以 对象.money = 新值 进行赋值 def money(self,money): return self.__money = money #删除 @money.deleter def money(self): del self.__money def get_money(self,flag): if flag == '自家人': return self.__money return 0 def set_money(self,money): self.__money += money a = AAA(88888) print(a.__money) #不能访问 #print(a.get_money('自家人')) #88888 #a.set_money(100000) #print(a.get_money('自家人')) #188888 print(a.money) #88888 a.money = 100000 print(a.money) #100000 del a.money print(a.money)