欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python中with語(yǔ)句結(jié)合上下文管理器操作詳解

 更新時(shí)間:2019年12月19日 10:42:17   作者:老王同鞋  
這篇文章主要給大家介紹了關(guān)于python中with語(yǔ)句結(jié)合上下文管理器操作的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用python具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

所謂上下文管理器即在一個(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ī)功能

    這篇文章主要介紹了使用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讀取txt文件并逐行輸出字符串

    python讀取txt文件并逐行輸出字符串

    Python提供了簡(jiǎn)單且方便的方法來(lái)讀取txt文件,使用open()函數(shù)和readlines()方法逐行輸出文件中的字符串內(nèi)容,我們可以輕松地讀取文件內(nèi)容,并通過(guò)循環(huán)遍歷的方式逐行處理,讀取txt文件的方法在各種應(yīng)用場(chǎng)景中非常常見(jiàn),可以用于數(shù)據(jù)分析、文本處理、日志分析等
    2023-10-10
  • 使用Python操作Excel中圖片的基礎(chǔ)示例(插入、替換、提取、刪除)

    使用Python操作Excel中圖片的基礎(chǔ)示例(插入、替換、提取、刪除)

    Excel是主要用于處理表格和數(shù)據(jù)的工具,我們也能在其中插入、編輯或管理圖片,為工作表增添視覺(jué)效果,提升報(bào)告的吸引力,本文將詳細(xì)介紹如何使用Python操作Excel中的圖片,文中有詳細(xì)代碼示例供大家參考,需要的朋友可以參考下
    2024-07-07
  • 如何用Python徒手寫(xiě)線性回歸

    如何用Python徒手寫(xiě)線性回歸

    這篇文章主要介紹了如何用Python徒手寫(xiě)線性回歸,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2021-01-01
  • 使用Python批量修改文件名的代碼實(shí)例

    使用Python批量修改文件名的代碼實(shí)例

    今天小編就為大家分享一篇關(guān)于使用Python批量修改文件名的代碼實(shí)例,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01
  • Python 實(shí)現(xiàn)圖像逐像素點(diǎn)取鄰域數(shù)據(jù)

    Python 實(shí)現(xiàn)圖像逐像素點(diǎn)取鄰域數(shù)據(jù)

    這篇文章主要介紹了Python 實(shí)現(xiàn)圖像逐像素點(diǎn)取鄰域數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-03-03
  • PyQt5+QtChart實(shí)現(xiàn)繪制極坐標(biāo)圖

    PyQt5+QtChart實(shí)現(xiàn)繪制極坐標(biāo)圖

    QChart是一個(gè)QGraphicScene中可以顯示的QGraphicsWidget。本文將利用QtChart實(shí)現(xiàn)極坐標(biāo)圖的繪制,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2022-12-12
  • Python基于ImageAI實(shí)現(xiàn)圖像識(shí)別詳解

    Python基于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-02
  • 11個(gè)Python Pandas小技巧讓你的工作更高效(附代碼實(shí)例)

    11個(gè)Python Pandas小技巧讓你的工作更高效(附代碼實(shí)例)

    這篇文章主要介紹了11個(gè)Python Pandas小技巧讓你的工作更高效(附代碼實(shí)例),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-04-04
  • python通過(guò)cookie模擬已登錄狀態(tài)的初步研究

    python通過(guò)cookie模擬已登錄狀態(tài)的初步研究

    對(duì)于那些需要在登錄環(huán)境下進(jìn)行的爬蟲(chóng)操作,模擬登陸或偽裝已登錄狀態(tài)是一個(gè)剛性需求。這篇文章主要介紹了python通過(guò)cookie模擬已登錄狀態(tài)的相關(guān)資料,需要的朋友可以參考下
    2016-11-11

最新評(píng)論