對于異常的使用上,當(dāng)我們在捕捉到錯誤時,會有一個拋出的選項讓我們做決定。不過加入了上下文管理器后,就不用對異常進行選擇了,因為其作用是不必拋出。下面我們就python上下文管理器處理異常進行說明,分析其中的三個參數(shù),最后帶來一個處理異常的實例供大家進行學(xué)習(xí)。
1、異常說明
異??梢栽赺_exit__ 進行捕獲并由你自己決定如何處理,是拋出還是不拋出。在__exit__ 里返回 True(沒有return 就默認為 return False),就相當(dāng)于告訴 Python解釋器,這個異常我們已經(jīng)捕獲了,不需要再往外拋了。
2、參數(shù)
在 寫__exit__ 函數(shù)時,需要注意的事,它必須要有這三個參數(shù):
- exc_type:異常類型
- exc_val:異常值
- exc_tb:異常的錯誤棧信息
當(dāng)主邏輯代碼沒有報異常時,這三個參數(shù)將都為None。
3、異常實例
如果我們需要對異常做特殊處理,就可以在這個方法中實現(xiàn)自定義邏輯。
之所以 with 能夠自動關(guān)閉文件資源,就是因為內(nèi)置的文件對象實現(xiàn)了上下文管理器協(xié)議,這個文件對象的 __enter__ 方法返回了文件句柄,并且在 __exit__ 中實現(xiàn)了文件資源的關(guān)閉,另外,當(dāng) with 語法塊內(nèi)有異常發(fā)生時,會拋出異常給調(diào)用者。
class File:
def __enter__(self):
return file_obj
def __exit__(self, exc_type, exc_value, exc_tb):
# with 退出時釋放文件資源
file_obj.close()
# 如果 with 內(nèi)有異常發(fā)生 拋出異常
if exc_type is not None:
raise exception
在__exit__方法中處理異常實例擴展:
class File(object):
def __init__(self, file_name, method):
self.file_obj = open(file_name, method)
def __enter__(self):
return self.file_obj
def __exit__(self, type, value, traceback):
print("Exception has been handled")
self.file_obj.close()
return True
with File('demo.txt', 'w') as opened_file:
opened_file.undefined_function()
# Output: Exception has been handled
到此這篇關(guān)于python上下文管理器異常問題解決方法的文章就介紹到這了,更多相關(guān)python上下文管理器如何解決異常內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- Python上下文管理器Content Manager
- 詳解python with 上下文管理器
- Python實現(xiàn)上下文管理器的方法
- python中with語句結(jié)合上下文管理器操作詳解
- Python上下文管理器類和上下文管理器裝飾器contextmanager用法實例分析
- Python上下文管理器實現(xiàn)方法總結(jié)