国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

Python實現(xiàn)上下文管理器的方法

瀏覽:5日期:2022-07-14 16:54:43

問題

你想自己去實現(xiàn)一個新的上下文管理器,以便使用with語句。

解決方案

實現(xiàn)一個新的上下文管理器的最簡單的方法就是使用 contexlib 模塊中的 @contextmanager 裝飾器。 下面是一個實現(xiàn)了代碼塊計時功能的上下文管理器例子:

import timefrom contextlib import contextmanager@contextmanagerdef timethis(label): start = time.time() try: yield finally: end = time.time() print(’{}: {}’.format(label, end - start))# Example usewith timethis(’counting’): n = 10000000 while n > 0: n -= 1

在函數(shù) timethis() 中,yield 之前的代碼會在上下文管理器中作為 __enter__() 方法執(zhí)行, 所有在 yield 之后的代碼會作為 __exit__() 方法執(zhí)行。 如果出現(xiàn)了異常,異常會在yield語句那里拋出。

下面是一個更加高級一點的上下文管理器,實現(xiàn)了列表對象上的某種事務:

@contextmanagerdef list_transaction(orig_list): working = list(orig_list) yield working orig_list[:] = working

這段代碼的作用是任何對列表的修改只有當所有代碼運行完成并且不出現(xiàn)異常的情況下才會生效。 下面我們來演示一下:

>>> items = [1, 2, 3]>>> with list_transaction(items) as working:... working.append(4)... working.append(5)...>>> items[1, 2, 3, 4, 5]>>> with list_transaction(items) as working:... working.append(6)... working.append(7)... raise RuntimeError(’oops’)...Traceback (most recent call last): File '<stdin>', line 4, in <module>RuntimeError: oops>>> items[1, 2, 3, 4, 5]>>>

討論

通常情況下,如果要寫一個上下文管理器,你需要定義一個類,里面包含一個 __enter__() 和一個 __exit__() 方法,如下所示:

import timeclass timethis: def __init__(self, label): self.label = label def __enter__(self): self.start = time.time() def __exit__(self, exc_ty, exc_val, exc_tb): end = time.time() print(’{}: {}’.format(self.label, end - self.start))

盡管這個也不難寫,但是相比較寫一個簡單的使用 @contextmanager 注解的函數(shù)而言還是稍顯乏味。

@contextmanager 應該僅僅用來寫自包含的上下文管理函數(shù)。 如果你有一些對象(比如一個文件、網絡連接或鎖),需要支持 with 語句,那么你就需要單獨實現(xiàn) __enter__() 方法和 __exit__() 方法。

以上就是Python實現(xiàn)上下文管理器的方法的詳細內容,更多關于Python實現(xiàn)上下文管理器的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 迁安市| 太原市| 敖汉旗| 南乐县| 三穗县| 盐源县| 鲁甸县| 沿河| 河南省| 奉节县| 宜州市| 潮州市| 瑞安市| 肃南| 区。| 峨眉山市| 镇赉县| 图们市| 临沧市| 东光县| 福清市| 吉安县| 扶绥县| 綦江县| 许昌市| 什邡市| 普宁市| 绿春县| 中江县| 德昌县| 韶山市| 公主岭市| 临沂市| 姜堰市| 石景山区| 遂昌县| 会泽县| 洪洞县| 沂南县| 祁阳县| 深圳市|