元類, pymysql
一、元類
- 自定義元類
'''
1、什么是元類?
- 類的類就是type,其實type就是元類
2、元類的作用?
3、如何創建元類以及使用?
'''
# # 1、一切皆物件
# list1 = [] # list1 = list([])
# print(type(list1)) #<class 'list'>
#
# # # 2、自定義一個類
# 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'>,
# 3、如何產生類
#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)
#1、什么是元類?
# 類的類就是type,其實type就是元類
# 2、為什么要使用元類?
# 因為元類可以控制類的創建程序
#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類括號中的值
# 1、造一個空物件obj
obj = object.__new__(self) # 創造一個空物件 self ---> User
print(obj.__dict__, 1111111)
# 2、呼叫類時,__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)
二、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()
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/95860.html
標籤:MySQL
下一篇:Mysql基礎02-約束
