好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Python上下文管理器Content Manager

Python上下文管理器Content Manager

熱門標簽:銀川電話機器人電話 企業彩鈴地圖標注 電銷機器人錄音要學習什么 煙臺電話外呼營銷系統 長春極信防封電銷卡批發 上海正規的外呼系統最新報價 預覽式外呼系統 外賣地址有什么地圖標注 如何地圖標注公司

在 Python 中,我們會經常聽到上下文管理器(Context Manager),那我們探討下這是什么,又有什么功能。

在 Python 中的上下文管理器中,使用 with 打開文件是使用最多的,其中離開 with 包含的語句后會執行一些類似于清理的工作,如關閉文件,關閉連接對象等操作。

實踐

我們在代碼實踐的時候,忽略了在同一代碼片段中,先打開文件,然后直接對文件進行其他處理,因為這樣沒有任何意義,資源是處于被占用的情況。

先看下面檢測的代碼:

#!/usr/bin/env python
# _*_ coding: UTF-8 _*_
# MedusaSorcerer Script
import os


class OpenFile:
    def __init__(self):
        self.file = None

    def open(self, path):
        self.file = open(path, 'w')


if __name__ == '__main__':
    file_path = 'medusa.md'
    file = OpenFile()
    file.open(file_path)
    os.remove(file_path)

代碼中我們把文件對象,進行了實例屬性的方式引用,在此之后,我們使用 os 模塊進行刪除被寫入的文件。執行改代碼片段后,會出現以下內容:

Traceback (most recent call last):
  File "medusa/main.py", line 19, in module>
    os.remove(file_path)
PermissionError: [WinError 32] 另一個程序正在使用此文件,進程無法訪問。: 'medusa.md'

Process finished with exit code 1

那是因為被刪除的文件沒有得到資源釋放。我們在上面的基礎上進行套用函數的方式:

#!/usr/bin/env python
# _*_ coding: UTF-8 _*_
# MedusaSorcerer Script
import os


class OpenFile:
    def __init__(self):
        self.file = None

    def open(self, path):
        self.file = open(path, 'w')


def open_file(path):
    file = OpenFile()
    file.open(path)


if __name__ == '__main__':
    file_path = 'medusa.md'
    open_file(file_path)
    os.remove(file_path)

這段代碼會成功的被執行成功,原因是當你執行函數的時候,函數內的臨時變量將被回收釋放,因此 OpenFile 的實例對象被釋放了,實例屬性也就不存在而被釋放,所以會執行成功。

那是否我們的操作都應該使用函數包裹的方式執行呢?with 的出現,完美解決了這個問題:

#!/usr/bin/env python
# _*_ coding: UTF-8 _*_
# MedusaSorcerer Script
import os

if __name__ == '__main__':
    file_path = 'medusa.md'
    with open(file_path, 'w') as f:
        print(f)
    os.remove(file_path)

在 with 語法中,將后面打開文件的操作,返回的文件對象,賦值給 f 變量,在結構體中輸出了 f 變量的內容,并且在結構體外刪除了該文件:

medusa\python.exe medusa/main.py
_io.TextIOWrapper name='medusa.md' mode='w' encoding='cp936'>

Process finished with exit code 0

在沒有使用 close() 的情況下,依舊可以對文件進行刪除,這就是上下文管理的美妙。

實現

上下文管理,實際上是實現了 __enter__ 和 __exit__ 方法:

#!/usr/bin/env python
# _*_ coding: UTF-8 _*_
# MedusaSorcerer Script


class Medusa:

    def __init__(self):
        print('__init__')

    def __enter__(self):
        print('__enter__')

    def __exit__(self, exc_type, exc_val, exc_tb):
        print('__exit__')


if __name__ == '__main__':
    medusa = Medusa()
    with medusa:
        print('with object')
    print('finish')

以下是輸出結果:

__init__
__enter__
with object
__exit__
finish

我們發現魔法方法在結合某些語法后會發生自動調度,所以,上下文管理中就在自動調度中,關閉了某些對象。

優點

實現上下文管理可以簡化我們的代碼,讓代碼更加簡單易讀,使用最少的代碼量,就可以完成全部工作。

到此這篇關于Python上下文管理器Content Manager的文章就介紹到這了,更多相關Python上下文管理器內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python上下文管理器異常問題解決方法
  • 詳解python with 上下文管理器
  • Python實現上下文管理器的方法
  • python中with語句結合上下文管理器操作詳解
  • Python上下文管理器類和上下文管理器裝飾器contextmanager用法實例分析
  • Python上下文管理器實現方法總結

標簽:佳木斯 珠海 盤錦 上饒 潮州 西寧 宜昌 湖北

巨人網絡通訊聲明:本文標題《Python上下文管理器Content Manager》,本文關鍵詞  Python,上下文,管理器,Content,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python上下文管理器Content Manager》相關的同類信息!
  • 本頁收集關于Python上下文管理器Content Manager的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 四大美女思春艳史片| 美女视频很黄很暴黄是免费的| 饥渴寡妇偷汉子视频| 疯狂的在小龙女体内冲撞| 国产精久久久久久精品电影蜜奴| 夜夜狠狠操| 岳潮湿的大肥| 加勒比色综合久久久久久久久| 毛片综合| 哈啊~孕夫高潮产子| 乳奴隷乳フ辱在线观看| 纯欧美一级暴毛片| 日韩欧美无线在码| 男人舔女人的阴部黄色骚虎视频| XXX高清偷拍女厕XXXX| 99热精品无码| 午夜精品久久久久久影院游戏| 国产精品无码视频| 色戒免费| 爽?躁多水?快?深小| 日本特黄特色大片免费视频在线播放| 国产?免费?在线?观看| 最近中文字幕经典版在线| 公交车上人妻无内裤做爰 | 另类露出暴露狂| 大尺度床戏带叫床再深一点| 在线亚洲精品国产波多野结衣| 三D肉蒲武则天秘史| 不卡一区二区三区卡| 老同学1在线观看免费完整版| 蜜桃婷婷狠狠久久综合9色第1集 | 天堂在线网| 韩国做爰无遮A片免费| 337P粉嫩曰本欧洲亚、、、、| 西毛扒嫩B| 昂不要自己坐下来| 九9热这里只有真品| 体育生帮体育老师口| 欧美日韩国产高清片| 1000部啪啪末满18勿入免费 | 亚洲热视频|