??我們明白了什么是異常后,那么發現異常后怎么處理,便是我們接下來要解決的問題。這里將處理異常的方式總結為五種。
1、默認異常處理機制
“默認”則說明是解釋器默認做出的行為,如果解釋器發現異常,并且我們沒有對異常進行任何預防,那么程序在執行過程中就會中斷程序,調用python默認的異常處理器,并在終端輸出異常信息。剛才舉過的例子:int(“m”),便是解釋器因為發現參數傳入異常,這種異常解釋器“無能為力”,所以它最后中斷了程序,并將錯誤信息打印輸出,告訴碼農朋友們:你的程序有bug!!!
2、try…except…處理機制
我們把可能發生錯誤的語句放在try語句里,用except來處理異常。每一個try,都必須至少有一個或者多個except。舉一個最簡單的例子如下,在try訪問number的第500個元素,很明顯數組越界訪問不了,這時候解釋器會發出異常信號:IndexError,接著尋找后面是否有對應的異常捕獲語句except,如果有則執行對應的except語句,待except語句執行完畢后,程序將繼續往下執行。如果沒有對應的except語句,即用戶沒有處理對應的異常,這時解釋器會直接中斷程序并將錯誤信息打印輸出。
number='hello'try:print(number[500])#數組越界訪問exceptIndexError:print("下標越界啦!")exceptNameError:print("未聲明對象!")print("繼續運行...")
輸出結果如下,因為解釋器發出異常信號是IndexError,所以執行下標越界語句。
下標越界啦!
繼續運行...
為了解鎖更多用法,我們再將例子改一下,我們依然在try訪問number的第500個元素,造成訪問越界錯誤,這里的except用了as關鍵字可以獲得異常對象,這樣子便可獲得錯誤的屬性值來輸出信息。
number='hello'try:print(number[500])#數組越界訪問exceptIndexErrorase:print(e)exceptExceptionase:#萬能異常
print(e)except:#默認處理所有異常
print("所有異常都可處理")print("繼續運行...")
輸出結果如下所示,會輸出系統自帶的提示錯誤:stringindexoutofrange,相對于解釋器因為異常自己拋出來的一堆紅色刺眼的字體,這種看起來舒服多了(能夠“運籌帷幄”的異常才是好異常嘛哈哈哈)。另外這里用到“萬能異常”Exception,基本所有沒處理的異常都可以在此執行。最后一個except表示,如果沒有指定異常,則默認處理所有的異常。
stringindexoutofrange繼續運行...
3、try…except…finally…處理機制
finally語句塊表示,無論異常發生與否,finally中的語句都要執行完畢。也就是可以很霸氣的說,無論產生的異常是被except捕獲到處理了,還是沒被捕獲到解釋器將錯誤輸出來了,都統統要執行這個finally。還是原來簡單的例子加上finally語句塊如下,代碼如下:
number='hello'try:print(number[500])#數組越界訪問,拋出IndexError異常exceptIndexError:print("下標越界啦!")finally:print("finally!")print("繼續運行...")#運行
結果如下,數據越界訪問異常被捕獲到后,先執行except語句塊,完畢后接著執行了finally語句塊。因為異常被執行,所以后面代碼繼續運行。
下標越界啦!finally!
繼續運行...
對try語句塊進行修改,打印abc變量值,因為abc變量沒定義,所以會出現不會被捕獲的NameError異常信號,代碼如下所示:
number='hello'try:print(abc)#變量未被定義,拋出NameError異常exceptIndexError:print("下標越界啦!")finally:print("finally!")print("繼續運行...")#不運行
結果如下,因為NameError異常信號沒法被處理,所以解釋器將程序中斷,并將錯誤信息輸出,但這過程中依然會執行finally語句塊的內容。因為程序被迫中斷了,所以后面代碼不運行。
finally!#異常沒被捕獲,也執行了finallyTraceback(mostrecentcalllast):
File"E:/Test_code/test.py",line3,in
print("abc")NameError:name'abc'isnotdefined
理解到這里,相信:try…finally…這種機制應該也不難理解了,因為省略了except捕獲異常機制,所以異常不可能被處理,解釋器會將程序中斷,并將錯誤信息輸出,但finally語句塊的內容依然會被執行。例子代碼如下:
number='hello'try:print(abc)#變量未被定義,拋出NameError異常finally:print("finally!")print("繼續運行...")
運行結果:
finally!#異常沒被捕獲,也執行了finallyTraceback(mostrecentcalllast):
File"E:/Test_code/test.py",line3,in
print("abc")NameError:name'abc'isnotdefined
4、assert斷言處理機制
assert語句先判斷assert后面緊跟的語句是True還是False,如果是True則繼續往下執行語句,如果是False則中斷程序,將錯誤信息輸出。
assert1==1#為True正常運行assert1==2#為False,終止程序,錯誤信息輸出
5、with…as處理機制
with…as一般常用在文件處理上,我們平時在使用類似文件的流對象時,使用完畢后要調用close方法關閉,很麻煩,這里with…as語句提供了一個非常方便且人性的替代方法,即使突發情況也能正常關閉文件。舉個例子代碼如下,open打開文件后將返回的文件流對象賦值給fd,然后在with語句塊中使用。
withopen('e:/test.txt','r')asfd:
fd.read()
print(abc)#變量未被定義,程序終止,錯誤信息輸出print("繼續運行...")
正常情況下,這里的with語句塊完畢之后,會自動關閉文件。但如果with語句執行中發生異常,如代碼中的變量未定義異常,則會采用默認異常處理機制,程序終止,錯誤信息輸出,后面代碼不被運行,文件也會正常關閉。
以上內容為大家介紹了python五大異常處理機制,希望對大家有所幫助,如果想要了解更多Python相關知識,請關注IT培訓機構:千鋒教育。http://www.dietsnews.net/