在項目開發中,異常處理是不可或缺的。異常處理幫助人們debug,通過更加豐富的信息,讓人們更容易找到bug的所在。異常處理還可以提高程序的容錯性。
我們之前在講循環對象的時候,曾提到一個StopIteration的異常,該異常是在循環對象窮盡所有元素時的報錯。
我們以它為例,來說明基本的異常處理。
一個包含異常的程序:
代碼如下:
re = iter(range(5))
for i in range(100):
print re.next()
print 'HaHaHaHa'
首先,我們定義了一個循環對象re,該循環對象將進行5次循環,每次使用序列的一個元素。
在隨后的for循環中,我們手工調用next()函數。當循環進行到第6次的時候,re.next()不會再返回元素,而是拋出(raise)StopIteration的異常。整個程序將會中斷。
我們可以修改以上異常程序,直到完美的沒有bug。但另一方面,如果我們在寫程序的時候,知道這里可能犯錯以及可能的犯錯類型,我們可以針對該異常類型定義好”應急預案“。
代碼如下:
re = iter(range(5))
try:
for i in range(100):
print re.next()
except StopIteration:
print 'here is end ',i
print 'HaHaHaHa'
在try程序段中,我們放入容易犯錯的部分。我們可以跟上except,來說明如果在try部分的語句發生StopIteration時,程序該做的事情。如果沒有發生異常,則except部分被跳過。
隨后,程序將繼續運行,而不是徹底中斷。
完整的語法結構如下:
代碼如下:
try:
...
except exception1:
...
except exception2:
...
except:
...
else:
...
finally:
...
如果try中有異常發生時,將執行異常的歸屬,執行except。異常層層比較,看是否是exception1, exception2...,直到找到其歸屬,執行相應的except中的語句。如果except后面沒有任何參數,那么表示所有的exception都交給這段程序處理。比如:
代碼如下:
try:
print(a*2)
except TypeError:
print("TypeError")
except:
print("Not Type Error & Error noted")
由于a沒有定義,所以是NameError。異常最終被except:部分的程序捕捉。
如果無法將異常交給合適的對象,異常將繼續向上層拋出,直到被捕捉或者造成主程序報錯。比如下面的程序
代碼如下:
def test_func():
try:
m = 1/0
except NameError:
print("Catch NameError in the sub-function")
新聞熱點
疑難解答