python學習筆記8.1-異常處理
阿新 • • 發佈:2019-01-09
程式設計師最大的天敵就是bug,所謂bug就是按照特定的輸入,卻沒有得到期望的相應,這個時候程式出了bug。bug是一定會存在的,有些是人為因素造成的,所以在程式設計的時候,我們要採取措施,儘量的減少bug的出現。python內建了我們常用到的異常處理機制,比如斷言,在程式設計的過程中,合理的使用這些異常處理機制,能幫我們減少很多除錯程式碼的時間。本文主要介紹一些異常處理機制的使用。
1. 函式一定要有返回值
這種方式涉及到我們的程式設計習慣。我們可以定義一種返回錯誤碼,例如-1,此時可以通過函式的返回值來定位錯誤的位置。
def func(x):
if isinstance(x,int):
return x
else:
return -1
res = func(1)
print(res)
res = func('1')
print(res)
2. 使用try…except…finally…錯誤處理機制
python中最常用的就是try…這種機制,需要注意的是:try, except, finally 三部分是獨立的,所以沒有except或者finally都是可以的。
try:
do right thing
except:
do error thing
finally:
do another thing
try中是正常執行的程式碼,except中是出現異常後執行的程式碼,finally中是一定會執行的程式碼。
try:
print('try is operated')
print(1/0)
except:
print('error')
finally:
print('finally')
在實際的應用中,我們一般用try去捕捉異常,但異常發生時,我們需要了解丟擲的異常的型別,以便去修正它。
2. 異常的型別
在python標準中,定義了一些標準的異常型別,這些型別可以直接使用。
異常名稱 | 描述 |
---|---|
BaseException | 所有異常的基類 |
SystemExit | 直譯器請求退出 |
KeyboardInterrupt | 使用者中斷執行(通常是輸入^C) |
Exception | 常規錯誤的基類 |
StopIteration | 迭代器沒有更多的值 |
GeneratorExit | 生成器(generator)發生異常來通知退出 |
SystemExit | Python 直譯器請求退出 |
StandardError | 所有的內建標準異常的基類 |
ArithmeticError | 所有數值計算錯誤的基類 |
FloatingPointError | 浮點計算錯誤 |
OverflowError | 數值運算超出最大限制 |
ZeroDivisionError | 除(或取模)零 (所有資料型別) |
AssertionError | 斷言語句失敗 |
AttributeError | 物件沒有這個屬性 |
EOFError | 沒有內建輸入,到達EOF 標記 |
EnvironmentError | 作業系統錯誤的基類 |
IOError | 輸入/輸出操作失敗 |
OSError | 作業系統錯誤 |
WindowsError | 系統呼叫失敗 |
ImportError | 匯入模組/物件失敗 |
KeyboardInterrupt | 使用者中斷執行(通常是輸入^C) |
LookupError | 無效資料查詢的基類 |
IndexError | 序列中沒有沒有此索引(index) |
KeyError | 對映中沒有這個鍵 |
MemoryError | 記憶體溢位錯誤(對於Python 直譯器不是致命的) |
NameError | 未宣告/初始化物件 (沒有屬性) |
UnboundLocalError | 訪問未初始化的本地變數 |
ReferenceError | 弱引用(Weak reference)試圖訪問已經垃圾回收了的物件 |
RuntimeError | 一般的執行時錯誤 |
NotImplementedError | 尚未實現的方法 |
SyntaxError | Python 語法錯誤 |
IndentationError | 縮排錯誤 |
TabError | Tab 和空格混用 |
SystemError | 一般的直譯器系統錯誤 |
TypeError | 對型別無效的操作 |
ValueError | 傳入無效的引數 |
UnicodeError | Unicode 相關的錯誤 |
UnicodeDecodeError | Unicode 解碼時的錯誤 |
UnicodeEncodeError | Unicode 編碼時錯誤 |
UnicodeTranslateError | Unicode 轉換時錯誤 |
Warning | 警告的基類 |
DeprecationWarning | 關於被棄用的特徵的警告 |
FutureWarning | 關於構造將來語義會有改變的警告 |
OverflowWarning | 舊的關於自動提升為長整型(long)的警告 |
PendingDeprecationWarning | 關於特性將會被廢棄的警告 |
RuntimeWarning | 可疑的執行時行為(runtime behavior)的警告 |
SyntaxWarning | 可疑的語法的警告 |
UserWarning | 使用者程式碼生成的警告 |
try:
print('try is operated')
print(1/0)
except ValueError:
print('error')
finally:
print('finally')
注意和上一個例子的比較,上一個例子中except後面沒有跟著錯誤型別,所以不會丟擲錯誤,程式碼會一直執行到結束。而這個例子中except後面有了錯誤型別,因而會丟擲錯誤。
為錯誤加上詳細資訊,
try:
print('try is operated')
print(1/0)
except ValueError('0 is not'):
print('error')
finally:
print('finally')
3. raise丟擲錯誤
有時候我們可以預先預料到某種錯誤的發生,此時可以用raise來丟擲錯誤。
x = input('please input a number:')
if x != 5:
raise ValueError
為錯誤加上更多的資訊:
x = input('please input a number:')
if x != 5:
raise ValueError('not my dream number')
4. assert斷言判斷錯誤
在3.中我們用了if…raise…來丟擲錯誤,如果利用assert…則不需要判斷。也就是說
assert的語法格式:
assert expression
它的等價語句為:
if not expression:
raise AssertionError
x = input('please input a number:')
assert x == 5,ValueError('not my number')
需要注意的是,assert 後面的條件為假時才丟擲錯誤,這是重點。