• python面向对象:小结


    从代码级别看面向对象

    1、在没有学习类这个概念时,数据与功能是分离的

    ef exc1(host,port,db,charset):
        conn=connect(host,port,db,charset)
        conn.execute(sql)
        return xxx
    
    
    def exc2(host,port,db,charset,proc_name)
        conn=connect(host,port,db,charset)
        conn.call_proc(sql)
        return xxx
    
    #每次调用都需要重复传入一堆参数
    exc1('127.0.0.1',3306,'db1','utf8','select * from tb1;')
    exc2('127.0.0.1',3306,'db1','utf8','存储过程的名字')
    

      

    2、能想到的解决方法是,把这些变量都定义成全局变量

    HOST=‘127.0.0.1’
    PORT=3306
    DB=‘db1’
    CHARSET=‘utf8’
    
    def exc1(host,port,db,charset):
        conn=connect(host,port,db,charset)
        conn.execute(sql)
        return xxx
    
    
    def exc2(host,port,db,charset,proc_name)
        conn=connect(host,port,db,charset)
        conn.call_proc(sql)
        return xxx
    
    exc1(HOST,PORT,DB,CHARSET,'select * from tb1;')
    exc2(HOST,PORT,DB,CHARSET,'存储过程的名字')
    

      

    3、但是2的解决方法也是有问题的,按照2的思路,我们将会定义一大堆全局变量,这些全局变量并没有做任何区分,即能够被所有功能使用,然而事实上只有host,port,db,charset是给exce1,和exc2这两个功能用的,言外之意:我们必须找出一种能够将数据与操作数据的方法组合到一起的解决方法,这就是我们说的类了

    from pymysql import connect
    
    
    class mysqlhandler:
        def __init__(self, host, port, db, charset="utf-8"):
            self.host = host
            self.port = port
            self.db = db
            self.charset = charset
            self.conn = connect(self.host, self.port, self.db, self.charset)
    
        def exc1(self, sql):
            return self.conn.execute(sql)
    
        def exc2(self, sql):
            return self.conn.call_proc(sql)
    
    
    obj = mysqlhandler('127.0.0.1', 3306, 'db1')
    obj.exc1('select * from tab1')
    obj.exc2('存储过程的名字')
    

      总结使用类可以:

    将数据与专门操作该数据的功能整合到一起
    

      

    可扩展性高

    定义类并产生三个对象

    class Chinese:
        def __init__(self,name,age,sex):
            self.name=name
            self.age=age
            self.sex=sex
    
    
    p1=Chinese('egon',18,'male')
    p2=Chinese('alex',38,'female')
    p3=Chinese('wpq',48,'female')
    

      

      

    如果我们新增一个类属性,将会立刻反映给所有对象,而对象却无需修改

    class chinese:
        country = 'China'
    
        def __init__(self, name, age, sex):
            self.name = name
            self.age = age
            self.sex = sex
    
        def tell_info(self):
            info = '''
            国籍:%s
            姓名:%s
            年龄:%s
            性别:%s
            ''' % (self.country, self.name, self.age, self.sex)
            print(info)
    
    
    p1 = chinese('egon', 18, 'male')
    p2 = chinese('alex', 33, 'female')
    p3 = chinese('wpq', 50, 'female')
    
    print(p1.country)
    p1.tell_info()
    

      

  • 相关阅读:
    myisamchk命令修复表操作
    CentOS下的yum upgrade和yum update区别
    CentOS 6.9/7通过yum安装指定版本的MySQL
    Linux下Shell去除空行的方法
    Linux下环境变量设置技巧
    交互设计师如何做运营需求-以网易严选邀请新人功能设计为例
    对应用启动时间的关注和获取
    快速发现并解决maven依赖传递冲突
    mock测试方法及实践改进
    网易杭研易盾实习心得(4)
  • 原文地址:https://www.cnblogs.com/mike-liu/p/9157946.html
Copyright © 2020-2023  润新知