python中with語(yǔ)句結(jié)合上下文管理器操作詳解
前言
所謂上下文管理器即在一個(gè)類(lèi)中重寫(xiě)了__enter__方法和__exit__方法的類(lèi)就可以成為上下文管理器類(lèi)。
我們可以通過(guò)with語(yǔ)句結(jié)合上下文管理器簡(jiǎn)化一些操作。
使用with語(yǔ)句結(jié)合自定義上下文管理器完成數(shù)據(jù)庫(kù)相應(yīng)的操作,代碼實(shí)現(xiàn)如下:
# 1. 導(dǎo)入模塊 import pymysql # 創(chuàng)建自定義上下文管理器對(duì)象 class MyDatabase(object): # 接收參數(shù)并創(chuàng)建數(shù)據(jù)庫(kù)連接對(duì)象 def __init__(self, host, port, user, passwd, database): self.__db = pymysql.Connection(host, port, user, passwd, database, charset='utf8') # 返回?cái)?shù)據(jù)庫(kù)連接對(duì)象 def __enter__(self): return self.__db # 關(guān)閉數(shù)據(jù)庫(kù)連接 def __exit__(self, exc_type, exc_val, exc_tb): self.__db.close() def main(): # 使用with關(guān)鍵字接收enter返回的對(duì)象給db with MyDatabase('localhost', 3306, 'root', 'mysql', 'JDDB') as db: # 利用db創(chuàng)建游標(biāo) cur = db.cursor() sql = '''select * from %s''' cur.execute(sql, (goods,)) result = cur.fetchall() for i in result: print(i) # 關(guān)閉游標(biāo) cur.close() # 程序入口 if __name__ == '__main__': main()
上下文管理器類(lèi)的代碼流程:
1.編寫(xiě)__init__方法用來(lái)接收參數(shù),并創(chuàng)建數(shù)據(jù)庫(kù)連接對(duì)象;
2.重寫(xiě)__enter__方法,返回?cái)?shù)據(jù)庫(kù)連接對(duì)象;
3.重寫(xiě)__exit__方法,用來(lái)關(guān)閉數(shù)據(jù)庫(kù)連接;
with語(yǔ)句代碼流程:
1.當(dāng)將創(chuàng)建對(duì)象的語(yǔ)句放到with語(yǔ)句里時(shí)不會(huì)創(chuàng)建對(duì)象,而是接受__enter__方法返回的對(duì)象并給對(duì)象起個(gè)別名;
2.使用接受到的對(duì)象即數(shù)據(jù)庫(kù)連接對(duì)象,創(chuàng)建游標(biāo);
3.編寫(xiě)SQL語(yǔ)句,并通過(guò)游標(biāo)執(zhí)行SQL語(yǔ)句;
4.獲取SQL語(yǔ)句的查詢(xún)結(jié)果,并顯示出來(lái);
5.關(guān)閉游標(biāo);
6.當(dāng)with語(yǔ)句內(nèi)的代碼執(zhí)行完畢后自動(dòng)執(zhí)行__exit__方法關(guān)閉數(shù)據(jù)庫(kù)連接。
注意:with MyDatabase() as db ---> db = MyDatabase().__enter__()
利用with結(jié)合自定義上下文類(lèi)實(shí)現(xiàn)HTTP服務(wù)端:
# 1.導(dǎo)入socket模塊 import socket class MySocket(object): # 2.編寫(xiě)init方法接收port參數(shù) def __init__(self, port): self.__port = port # 3.創(chuàng)建socket對(duì)象 self.__sk = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 4.編寫(xiě)enter方法返回套接字對(duì)象 def __enter__(self): # 設(shè)置端口復(fù)用 self.__sk.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True) # 綁定端口 self.__sk.bind(self.__port) # 設(shè)置端口監(jiān)聽(tīng) self.__sk.listen(128) # 返回套接字對(duì)象 return self.__sk # 5.編寫(xiě)exit方法關(guān)閉套接字對(duì)象 def __exit__(self, exc_type, exc_val, exc_tb): self.__sk.close() def main(): # 使用with關(guān)鍵字 并接受返回的套接字對(duì)象給sk with MySocket(8000) as sk: # 等待客戶(hù)端連接 clicent, ip_port = sk.accept() recv_data = clicent.recv(1024) print(recv_data.decode('utf-8')) # 編寫(xiě)HTTP響應(yīng)報(bào)文 http_line = 'HTTP/1.1 GET 200 OK\r\n' http_header = 'Server PWS/1.0\r\n' http_body = 'Welcome to index!\r\n' send_data = (http_line + http_header + '\r\n' + http_body).encode('utf-8') clicent.send(send_data) # 關(guān)閉客戶(hù)端連接 clicent.close() # 編寫(xiě)程序入口 if __name__ == '__main__': main()
自定義上下文管理器類(lèi)的代碼解讀:
1.編寫(xiě)__init__方法,用來(lái)接收參數(shù)并創(chuàng)建套接字對(duì)象;
2.編寫(xiě)__enter__方法,并使用套接字對(duì)象設(shè)置端口復(fù)用、綁定端口、并設(shè)置監(jiān)聽(tīng),然后返回套接字對(duì)象;
3.編寫(xiě)__exit__方法,關(guān)閉套接字對(duì)象。
with語(yǔ)句代碼解讀:
1.接收enter返回的套接字對(duì)象,并起個(gè)別名,
2.通過(guò)返回套接字對(duì)象等待客戶(hù)端連接,
3.接收客戶(hù)端連接成功后會(huì)返回一個(gè)新的套接字和IP端口號(hào),
4.使用客戶(hù)端套接字發(fā)送HTTP響應(yīng)報(bào)文
5.關(guān)閉客戶(hù)端連接
6.當(dāng)with語(yǔ)句中的代碼執(zhí)行完畢后自動(dòng)執(zhí)行__exit__方法,關(guān)閉服務(wù)器連接
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
使用Python實(shí)現(xiàn)Wake On Lan遠(yuǎn)程開(kāi)機(jī)功能
這篇文章主要介紹了使用Python實(shí)現(xiàn)Wake On Lan遠(yuǎn)程開(kāi)機(jī)功能,文中給大家補(bǔ)充介紹了python通過(guò)wakeonlan喚醒內(nèi)網(wǎng)電腦開(kāi)機(jī),非常不錯(cuò),感興趣的朋友跟隨小編一起學(xué)習(xí)吧2020-01-01使用Python操作Excel中圖片的基礎(chǔ)示例(插入、替換、提取、刪除)
Excel是主要用于處理表格和數(shù)據(jù)的工具,我們也能在其中插入、編輯或管理圖片,為工作表增添視覺(jué)效果,提升報(bào)告的吸引力,本文將詳細(xì)介紹如何使用Python操作Excel中的圖片,文中有詳細(xì)代碼示例供大家參考,需要的朋友可以參考下2024-07-07Python 實(shí)現(xiàn)圖像逐像素點(diǎn)取鄰域數(shù)據(jù)
這篇文章主要介紹了Python 實(shí)現(xiàn)圖像逐像素點(diǎn)取鄰域數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03PyQt5+QtChart實(shí)現(xiàn)繪制極坐標(biāo)圖
QChart是一個(gè)QGraphicScene中可以顯示的QGraphicsWidget。本文將利用QtChart實(shí)現(xiàn)極坐標(biāo)圖的繪制,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-12-12Python基于ImageAI實(shí)現(xiàn)圖像識(shí)別詳解
ImageAI是一個(gè)面向計(jì)算機(jī)視覺(jué)編程的Python庫(kù),支持最先進(jìn)的機(jī)器學(xué)習(xí)算法。本文將利用ImageAI實(shí)現(xiàn)圖像識(shí)別功能,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-02-0211個(gè)Python Pandas小技巧讓你的工作更高效(附代碼實(shí)例)
這篇文章主要介紹了11個(gè)Python Pandas小技巧讓你的工作更高效(附代碼實(shí)例),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-04-04python通過(guò)cookie模擬已登錄狀態(tài)的初步研究
對(duì)于那些需要在登錄環(huán)境下進(jìn)行的爬蟲(chóng)操作,模擬登陸或偽裝已登錄狀態(tài)是一個(gè)剛性需求。這篇文章主要介紹了python通過(guò)cookie模擬已登錄狀態(tài)的相關(guān)資料,需要的朋友可以參考下2016-11-11