元類, pymysql

元類, pymysql

1、元類

  • 自定義元類
'''
一、什麼是元類?
    - 類的類就是type,其實type就是元類

二、元類的做用?

三、如何建立元類以及使用?
'''

# # 一、一切皆對象
# list1 = []  # list1 = list([])
# print(type(list1))  #<class 'list'>

#
# # # 二、自定義一個類
# class Chinese(object):
#     country = 'china'
#
#     def __init__(self, name, age, sex):
#         self.name = name
#         self.age = age
#         self.sex = sex
#
#
# obj = Chinese('yafeng', 18, 'male')
# print(type(obj))   #<class '__main__.Chinese'>
# print(Chinese)    #類本質上也是一個對象,Python中一且皆對象
# # <class '__main__.Chinese'>,


# 三、如何產生類
#1) 經過class關鍵字產生類
#2) 經過調用type類:type()  ----> obj ---->Chinese


# what:指的是類名
# bases:繼承的父類(object)
# dict:類的名稱空間

#
# code = '''
# country = 'china'
# def __init__(self, name, age, sex):
#     self.name = name
#     self.age = age
#     self.sex = sex
# '''

# class_attr = {}
# exec(code, {}, class_attr)
#
#
# # type(類的名字, 類的基類,類的名稱空間)
# obj = type('Chinese', (object, ), class_attr)
# print(obj)  #<class '__main__.Chinese'>
# print(Chinese)

#一、什麼是元類?
# 類的類就是type,其實type就是元類


# 二、爲何要使用元類?
# 由於元類能夠控制類的建立過程

#type是python內置的元類


# 自定義一個元類
class MyMetaClass(type):


    #控制類的建立
    # 優酷須要使用的部分
    def __init__(self, class_name, class_bases, class_dict):
        print(type(class_name))

        #要求類的首字母必須大寫
        if not class_name.istitle():
            raise NameError('類的首字母必須大寫!')

        # 規定類必需要寫註釋
        if not class_dict.get('__doc__'):
            raise TypeError('必須得寫註釋!!!')

        # 必須將類的類名,類的基類,類的名稱空間一併返給 type 中的__init__
        super().__init__(class_name, class_bases, class_dict)



    # 瞭解:元類更深層次的做用
    # 控制調用類的行爲
    # 爲何調用類就必定會產生一個空對象,爲何必定會執行__new__
    # 其實就是type 內部必定會調用一次__call__,有__call__來幫你調用__new__

    # 元類中的__call__就是建立類的過程!!!
    def __call__(self, *args, **kwargs):
        print(args)   # User類括號中的值
        # 一、造一個空對象obj
        obj = object.__new__(self) # 創造一個空對象 self ---> User

        print(obj.__dict__, 1111111)

        # 二、調用類時,__call__會立馬調用User.__init__, 而且將obj連同User括號內的參數一同傳給__init__
        self.__init__(obj, *args, **kwargs)

        # return 一個真正建立的對象
        return obj


## obj = MyMetaClass()
# obj()   # obj()---->  User(10,20) ---->user_obj


# 被控制類在定義階段 類名(metaclass=自定義的元類)---->會將當前類的類名、基類、類的名稱空間  一併傳給 自定義的元類

# metaclass --->自定義的元類看---->低調作那個自定義的元類(類名,基類,類的名稱空間)

# type(類名,基類,類的名稱空間)

class User(object, metaclass=MyMetaClass):  # MyMetaClass(User, (object,), {'x':10})

    '''我要成爲年薪百萬的男人,tank老師很好啊,向他學習'''

    def __init__(self):
        pass

    x = 10
    pass


obj = User()

print(obj)

2、pymysql

  • 經過pymysql 去鏈接數據庫
# 下載第三方模塊:在cmd 中下載

# pip install pymysql



# 麪條版
import pymysql

# 1.鏈接數據庫
client = pymysql.connect(
    host='127.0.0.1',
    port=3306,
    user='root',
    password='123456',
    database='db4',
    charset='utf8',  #此處不能寫utf-8
    autocommit=True
)

# print(client)


# 2.獲取遊標對象 ---->遊標 能夠用來提交sql命令
course_obj = client.cursor(pymysql.cursors.DictCursor)


# 3.經過execute 能夠提交sql語句

# 1) 查數據
# sql = 'select * from emp'
#
# # 提交sql語句
# course_obj.execute(sql)
#
# #4.提交後,經過cursor_obj 對象.fetchall()  獲取全部查詢到的結果
#
# res = course_obj.fetchall()
# print(res)
#
# for dic in res:
#     print(dic)

# 2) 插入數據
# 建立表
# sql = 'create table user(id int, name varchar(16))'
# course_obj.execute(sql)
#
# sql = 'insert into user(id, name) values(1, "yafeng")'
# course_obj.execute(sql)


# 注意得運行後才能夠上傳到數據庫


# 3) 更新數據
# try:
#     sql = 'update user set name="yafeng_很帥" where id=1'
#
#     course_obj.execute(sql)
#
# except Exception as e:
#     print(e)

# # 4) 刪除數據
# sql = 'delete from user'
# course_obj.execute(sql)

# 關閉遊標
# course_obj.close()
#
#
# # 關閉客戶端鏈接
# client.close()
相關文章
相關標籤/搜索