zoukankan      html  css  js  c++  java
  • Python之面向对象

      面向过程

      事例:两个人一天干以下几件事:

      1. 张三: 起床---吃饭---工作---吃饭---工作---吃饭---工作---回家---睡觉

      2. 李四: 起床---吃饭---学习---吃饭---学习---回家---玩耍---睡觉

    #cat 面向过程.py
    def get_up(name):
        print("{}起床".format(name))
    
    def eat(name):
        print("{}吃饭".format(name))
    
    def go_to_work(name):
        print("{}工作中".format(name))
    
    def go_to_school(name):
        print("{}学习中".format(name))
    
    def go_to_play(name):
        print("{}玩耍中".format(name))
    
    def go_home(name):
        print("{}回家".format(name))
    
    def go_to_bed(name):
        print("{}睡觉".format(name))
    
    get_up("zhangsan")
    eat("zhangsan")
    go_to_work("zhangsan")
    go_to_school("zhangsan")
    go_to_play("zhangsan")
    go_home("zhangsan")
    go_to_bed("zhangsan")
    

      类与对象

      类是总结事物特征的抽象概念,是创建对象的模板。对象是安装类来具体出来的实物

      举例说明

       玩具模型就是类

      具体生产出来的玩具就是对象

      类就是一个模板,对象是通过模板创建出来的具体的实物

      类的构成

      类的名称:类名

      类的属性:一组参数数据

      类的方法:操作的方式或行为

      如:为人设计一个类

      名称: People

      属性:name,sex,age,weight,height等

      方法:eat,drink,walk,run

      类的创建

    class People(object): # 创建类,使用驼峰式命名
        pass
    

      创建对象 给对象附加属性

    p1 = People()
    p2 = People()
    # 给对象加属性,不是给类加属性
     p1.name = "张三"
    p1.sex = "男"
    
    p2.name = "李四"
    p2.sex = "女"
    

      以上是直接给对象加属性,非给类加属性

      给类加属性

    class People(object): # 创建类,使用驼峰式命名
        def __init__(self, name, sex):  # 定义类的属性
            self.name = name
            self.sex = sex
    
    p1 = People("张三", "男")   # 通过类创建对象,即类的实例化 p1 = self p1.name="张三" sex="男"
    p2 = People("李四", "女")
    

      给类加方法

    class People(object): # 创建类,使用驼峰式命名
        def __init__(self, name, sex):  # 定义类的属性
            self.name = name
            self.sex = sex
    
        def info(self): # 定义类的方法
            print(self.name, self.sex)
    
    p1 = People("张三", "男")   # 通过类创建对象,即类的实例化 p1 = self p1.name="张三" sex="男"
    p2 = People("李四", "女")
    
    print(id(p1))   # 两个对象的内存空间不一样,所以是两个不同的对象
    print(id(p2))
    
    # 给对象加属性,不是给类加属性
    # p1.name = "张三"
    # p1.sex = "男"
    #
    # p2.name = "李四"
    # p2.sex = "女"
    
    p1.info()   # 调用类的方法打印姓名和性别
    p2.info()
    

      类的变量

      示例

    #cat 类的变量.py
    class People(object):
        name = "haha"    # 类变量
    
        def __init__(self, name, sex):
            self.name = name    # 示例变量
            self.sex = sex
    
        def info(self):
            print(self.name, self.sex)
    
    p1 = People("zhangsan", "man")
    print(People.name)   # 可以打印类变量的值为haha
    print(p1.name)       # 类变量与实例变量同名,实例变量优先于类变量 值为zhangsan 
    

      注意:类变量,实例1,实例2都是独立的内存空间,修改互不影响

      示例

    # cat 类的变量2.py
    class People(object):
        abc = "haha"    # 类变量
    
        def __init__(self, name, sex):
            self.name = name    # 实例变量
            self.sex = sex
    
        def info(self):
            print(self.name, self.sex)
    
    p1 = People("zhangsan", "man")
    p2 = People("lisi", "women")
    
    p1.abc = "hehe" # 对p1实例的类变量赋值hehe
    print(p1.abc)   # 结果为赋值后的hehe
    print(p2.abc)   # 结果仍然为haha说明修改p1不影响p2
    print(People.abc)   # 结果仍然为haha,说明修改p1也不影响类变量本身
    

      __str__和__del__

    # cat 面向对象str和del.py
    class Hero(object):
        def __init__(self, name):
            self.name = name
    
        def __str__(self):  # print对象时调用__str__
            return "我叫{},我为自己代言".format(self.name)
    
        def __del__(self):
            print("......我{}还会回来的......".format(self.name))
    
    hero1 = Hero("亚瑟")
    hero2 = Hero("后羿")
    
    print(hero1)    # 执行print调用__str__
    # 我叫亚瑟,我为自己代言
    print(hero2)
    # 我叫后羿,我为自己代言
    
    # 结束以后执行__del__输出以下
    # ......我亚瑟还会回来的......
    # ......我后羿还会回来的......
    del hero1
    del hero2
    
    print("="*30)
    

      小结

       对象销毁包括执行结束了或者是删除了对象

      私有属性和私有方法

      一般情况下私有属性和私有方法是不对外公开的,只能在类的内部调用,往往用来做内部的事情,起到安全的作用

    # cat 私有属性和私有方法.py
    class People(object):
        __country = "china"    # 前面加上__ 就成了私有类属性,不能被外部直接调用
    
        def __init__(self, name, sex):
            self.name = name
            self.__sex = sex    # 前面加上__就成了私有对象属性,不能被外部调用
    
        def __info(self):   # 前面加上__成了私有方法,不能被外部调用
            print(self.name, self.sex)
    
    p1 = People("zhangsan", "man")
    
    # print(p1.sex)
    # print(p1.__sex)
    # print(p1.country)
    # print(p1.__country)
    # p1.info()
    # p1.__info()
    # 以上取消注释执行均会报错 类似报错 'People' object has no attribute '__info'
    

      示例: 如果类的外部需要调用到私有属性的值,可以对私有属性单独定义一个类的方法,让实例通过调用此方法来调用私有属性(私有方法同理)

      示例如下

    # cat 私有属性和私有方法2.py
    class People(object):
        __country = "china"    # 前面加上__ 就成了私有类属性,不能被外部直接调用
    
        def __init__(self, name, sex):
            self.name = name
            self.__sex = sex    # 前面加上__就成了私有对象属性,不能被外部调用
    
        def __info(self):   # 前面加上__成了私有方法,不能被外部调用
            print(self.name, self.__sex)
    
        def show_country(self): # 内部调用私有类属性
            print(self.__country)
    
        def show_sex(self): # 内部调用私有对象属性
            print(self.__sex)
    
        def show_info(self):
            return People.__info(self)
    
    p1 = People("zhangsan", "man")
    p1.show_country()   # 调用非私有方法即相当于在类内部调用私有属性
    p1.show_sex()
    p1.show_info()
    

      继承

      继承的作用: 减少代码的冗余,便于功能的升级(原有的功能进行完善)与扩展(原没有的功能进行添加)

      继承示例

    # cat 继承.py
    class People(object):
        def __init__(self, name, age):
            self.name = name
            self.age = age
    
        def eat(self):
            print("come to eat,{}".format(self.name))
    
        def drink(self):
            print("come to drink,{}".format(self.name))
    
    class Man(People):  # 表示Man类继承父类 People
        def work(self): # 类Man自定义的方法,Woman不能调用此方法
            print("come to work,{}".format(self.name))
    
    class Woman(People): # 表示Woman类继承父类 People
        pass
    
    m1 = Man("zhansan", 16)
    m1.eat()    # 继承了父类,可以调用父类的方法
    m1.drink()
    m1.work()
    
    m2 = Woman("lisi", 18)
    m2.eat()
    m2.drink()
    

      方法重写

    # cat 在子类重写父类方法.py
    class People(object):
        def __init__(self, name, age):
            self.name = name
            self.age = age
    
        def eat(self):
            print("come to eat,{}".format(self.name))
    
        def drink(self):
            print("come to drink,{}".format(self.name))
    
    class Man(People):  # 表示Man类继承父类 People
        def drink(self):
            if self.age >= 18:
                print("you can drink")
            else:
                print("you can't drink")
    
    class Woman(People): # 表示Woman类继承父类 People
        pass
    
    m1 = Man("zhansan", 18)
    m1.eat()
    m1.drink()  # 优先调用子类的方法 所以会根据输入的年龄大小分别输出you can drink或者you can't drink不会调用父类People的方法
    

      子类重新创建属性

    # cat 子类重新构造属性.py
    class People(object):
        def __init__(self, name, age):
            self.name = name
            self.age = age
    
        def eat(self):
            print("come to eat,{}".format(self.name))
    
        def drink(self):
            print("come to drink,{}".format(self.name))
    
    
    class Woman(People): # 表示Woman类继承父类 People
        def __init__(self, name, age, bra_size):    # 子类新加一个属性,需要和原父类属性对应
            People.__init__(self, name, age)    # 经典写法;换成super(Woman,self).__init__(name, age)也一样(新式类写法)
            # super(Woman, self).__init__(name, age)
            self.bra_size = bra_size
    
        def info(self):
            print("姓名 {} 年龄 {} 罩杯 {}".format(self.name, self.age, self.bra_size))
    
    w1 = Woman("lisi", 18, "D")
    w1.eat()
    w1.info()
    

      多层继承

      类可以多层继承,下一级子类拥有上一层父类的属性和方法

      示例

    # cat 多层继承一.py
    class Grandfather():
        def house(self):
            print("a big hose!")
    
    class Father(Grandfather):
        def car(self):
            print("a cool car!")
    
    class Child(Father):
        pass
    
    p1 = Child()    # Child继承了Father Father继承了Grandfather 所以Child也有了Grandfather里的方法
    p1.house()
    

      示例二

    # cat 多层继承二.py
    class People():
        def __init__(self, name, sex):
            self.name = name
            self.sex = sex
    class Love(People):
        def fall_in_love(self,obj):
            if self.sex == "男":
                print("{}向{}求婚".format(self.name,obj.name))
            elif self.sex == "女":
                print("{}要给{}生猴子".format(self.name,obj.name))
            else:
                print("性别输入有误")
    class Man(Love):
        pass
    class Woman(Love):
        pass
    m1=Man("张三","男")
    w1=Woman("李四","女")
    m1.fall_in_love(w1)
    w1.fall_in_love(m1)
    

      多继承

      一个子类可以继承多个父类

      示例

    # cat 多继承一.py
    class Father(object):
        def sing(self):
            print("can sing")
    
    class Mother(object):
        def dance(self):
            print("can dance")
    
    class Child(Father, Mother):    # 子类继承了两个父类
        pass
    
    p1 = Child()
    p1.sing()   # 同时拥有两个父类的方法
    p1.dance()
    

      多态

       多态:一类事物有多种形态。例如水有水蒸气,液态水,冰等多种状态

      python变量本身是没有类型的,变量类型是由赋值觉得的。可以是int,也可以是str,这其实就是一种多态。

       示例

    # cat 多态1.py
    class Animal(object):
        def jiao(self):
           pass
    
    class Dog(Animal):
        def jiao(self):
            print("wang wang ...")
    
    class Cat(Animal):
        def jiao(self):
            print("miao miao ...")
    
    d1 = Dog()
    c1 = Cat()
    
    d1.jiao()   # 对象接类的方法调用,结果是狗叫
    c1.jiao()   # 对象接类的方法调用,结果是猫叫
    

      统一调用方法

    # cat 多态二.py
    class Animal(object):
        def jiao(self):
            pass
    
    class Dog(Animal):
        def jiao(self):
            print("wang wang ...")
    
    class Cat(Animal):
        def jiao(self):
            print("miao miao ...")
    
    def jiao(obj):
        obj.jiao()
    
    d1 = Dog()
    c1 = Cat()
    
    jiao(d1)    # 统一调用方法,不管对象是狗还是猫,调用方法是一致的
    jiao(c1)
    

      

      

  • 相关阅读:
    设计模式 --建造者模式
    HIVE
    Sqoop Mysql导入Hive完整命令参数解析
    Centos7 安装CDH6.3.2 集群
    sqlalchemy 批量插入
    前后端分离
    后台管理模板
    Springboot
    汇编基础
    百万点数据矢量切片实时聚合展示
  • 原文地址:https://www.cnblogs.com/minseo/p/13962362.html
Copyright © 2011-2022 走看看