Python中的異常處理講解
一、什么是異常
在python中,錯(cuò)誤觸發(fā)的異常如下
二、異常的種類
在python中不同的異??梢杂貌煌念愋腿?biāo)識(shí),一個(gè)異常標(biāo)識(shí)一種錯(cuò)誤。
1 、常用異常類
- AttributeError 試圖訪問(wèn)一個(gè)對(duì)象沒(méi)有的樹(shù)形,比如foo.x,但是foo沒(méi)有屬性x
- IOError 輸入/輸出異常;基本上是無(wú)法打開(kāi)文件
- ImportError 無(wú)法引入模塊或包;基本上是路徑問(wèn)題或名稱錯(cuò)誤
- IndentationError 語(yǔ)法錯(cuò)誤(的子類) ;代碼沒(méi)有正確對(duì)齊
- IndexError 下標(biāo)索引超出序列邊界,比如當(dāng)x只有三個(gè)元素,卻試圖訪問(wèn)x[5]
- KeyError 試圖訪問(wèn)字典里不存在的鍵
- KeyboardInterrupt Ctrl+C被按下
- NameError 使用一個(gè)還未被賦予對(duì)象的變量
- SyntaxError Python代碼非法,代碼不能編譯(個(gè)人認(rèn)為這是語(yǔ)法錯(cuò)誤,寫錯(cuò)了)
- TypeError 傳入對(duì)象類型與要求的不符合
- UnboundLocalError 試圖訪問(wèn)一個(gè)還未被設(shè)置的局部變量,基本上是由于另有一個(gè)同名的全局變量,導(dǎo)致你以為正在訪問(wèn)它
- ValueError 傳入一個(gè)調(diào)用者不期望的值,即使值的類型是正確的
2、異常舉例:
# TypeError:int類型不可迭代 for i in 3: pass # ValueError num=input(">>: ") #輸入hello int(num) # NameError aaa # IndexError l=['egon','aa'] l[3] # KeyError dic={'name':'egon'} dic['age'] # AttributeError class Foo:pass Foo.x # ZeroDivisionError:無(wú)法完成計(jì)算 res1=1/0 res2=1+'str'
三、異常處理
1、基本語(yǔ)法try...except
try: 被檢測(cè)的代碼塊 except 異常類型: try中一旦檢測(cè)到異常,就執(zhí)行這個(gè)位置的邏輯
舉例
try: f = [ 'a', 'a', 'a','a','a', 'a','a',] g = (line.strip() for line in f) #元組推導(dǎo)式 print(next(g)) print(next(g)) print(next(g)) print(next(g)) print(next(g)) except StopIteration: f.close()
異常類只能用來(lái)處理指定的異常情況,如果非指定異常則無(wú)法處理。
s1 = 'hello' try: int(s1) except IndexError as e: # 未捕獲到異常,程序直接報(bào)錯(cuò) print(e)
2、多分支異常 except..except與萬(wàn)能異常:Exception
s1 = 'hello' try: int(s1) except IndexError as e: print(e) except KeyError as e: print(e) except ValueError as e: print(e) except Exception as e: print(e)
3、try/except...else
try/except 語(yǔ)句還有一個(gè)可選的 else 子句,如果使用這個(gè)子句,那么必須放在所有的 except 子句之后。
else 子句將在 try 子句沒(méi)有發(fā)生任何異常的時(shí)候執(zhí)行。
for arg in sys.argv[1:]: try: f = open(arg, 'r') except IOError: print('cannot open', arg) else: print(arg, 'has', len(f.readlines()), 'lines') f.close()
4、異常的最終執(zhí)行finally
try-finally 語(yǔ)句無(wú)論是否發(fā)生異常都將執(zhí)行最后的代碼。
定義清理行為:
s1 = 'hello' try: int(s1) except IndexError as e: print(e) except KeyError as e: print(e) except ValueError as e: print(e) #except Exception as e: # print(e) else: print('try內(nèi)代碼塊沒(méi)有異常則執(zhí)行我') finally: print('無(wú)論異常與否,都會(huì)執(zhí)行該模塊,通常是進(jìn)行清理工作')
#invalid literal for int() with base 10: 'hello'
#無(wú)論異常與否,都會(huì)執(zhí)行該模塊,通常是進(jìn)行清理工作
四、拋出異常raise
Python 使用 raise 語(yǔ)句拋出一個(gè)指定的異常。
raise語(yǔ)法格式如下:
raise [Exception [, args [, traceback]]]
try: raise TypeError('拋出異常,類型錯(cuò)誤') except Exception as e: print(e)
raise 唯一的一個(gè)參數(shù)指定了要被拋出的異常。它必須是一個(gè)異常的實(shí)例或者是異常的類(也就是 Exception 的子類)。
如果你只想知道這是否拋出了一個(gè)異常,并不想去處理它,那么一個(gè)簡(jiǎn)單的 raise 語(yǔ)句就可以再次把它拋出。
try: raise NameError('HiThere') except NameError: print('An exception flew by!') raise #An exception flew by! #Traceback (most recent call last): # File "", line 2, in ? #NameError: HiThere
五、自定義異常
你可以通過(guò)創(chuàng)建一個(gè)新的異常類來(lái)?yè)碛凶约旱漠惓?。異常類繼承自 Exception 類,可以直接繼承,或者間接繼承,例如:
在這個(gè)例子中,類 Exception 默認(rèn)的 __init__() 被覆蓋。
class EgonException(Exception): def __init__(self, msg): self.msg = msg def __str__(self): return self.msg try: raise EgonException('拋出異常,類型錯(cuò)誤') except EgonException as e: print(e) #拋出異常,類型錯(cuò)誤
基礎(chǔ)異常類
當(dāng)創(chuàng)建一個(gè)模塊有可能拋出多種不同的異常時(shí),一種通常的做法是為這個(gè)包建立一個(gè)基礎(chǔ)異常類,然后基于這個(gè)基礎(chǔ)類為不同的錯(cuò)誤情況創(chuàng)建不同的子類:
大多數(shù)的異常的名字都以"Error"結(jié)尾,就跟標(biāo)準(zhǔn)的異常命名一樣。
class Error(Exception): """Base class for exceptions in this module.""" pass class InputError(Error): """Exception raised for errors in the input. Attributes: expression -- input expression in which the error occurred message -- explanation of the error """ def __init__(self, expression, message): self.expression = expression self.message = message class TransitionError(Error): """Raised when an operation attempts a state transition that's not allowed. Attributes: previous -- state at beginning of transition next -- attempted new state message -- explanation of why the specific transition is not allowed """ def __init__(self, previous, next, message): self.previous = previous self.next = next self.message = message
六、斷言assert
assert(斷言)用于判斷一個(gè)表達(dá)式,在表達(dá)式條件為 false 的時(shí)候觸發(fā)異常。
斷言可以在條件不滿足程序運(yùn)行的情況下直接返回錯(cuò)誤,而不必等待程序運(yùn)行后出現(xiàn)崩潰的情況。
語(yǔ)法格式如下:
assert expression
等價(jià)于:
if not expression: raise AssertionError
assert 后面也可以緊跟參數(shù):
assert expression [, arguments]
等價(jià)于:
if not expression: raise AssertionError(arguments)
以下實(shí)例判斷當(dāng)前系統(tǒng)是否為 Linux,如果不滿足條件則直接觸發(fā)異常,不必執(zhí)行接下來(lái)的代碼:
import sys assert ('linux' in sys.platform), "該代碼只能在 Linux 下執(zhí)行" # 接下來(lái)要執(zhí)行的代碼 # Traceback (most recent call last): # File "C:/PycharmProjects/untitled/run.py", line 2, in # assert ('linux' in sys.platform), "該代碼只能在 Linux 下執(zhí)行" # AssertionError: 該代碼只能在 Linux 下執(zhí)行
到此這篇關(guān)于Python異常處理的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Pytorch中index_select() 函數(shù)的實(shí)現(xiàn)理解
這篇文章主要介紹了Pytorch中index_select() 函數(shù)的實(shí)現(xiàn)理解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11Python?pyecharts?Boxplot箱線圖的實(shí)現(xiàn)
本文主要介紹了Python?pyecharts?Boxplot箱線圖的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05基于python介紹pytorch保存和恢復(fù)參數(shù)
這篇文章主要介紹了基于python介紹pytorch保存和恢復(fù)參數(shù),為了恢復(fù)模型,我們需要用代碼生成框架,然后從磁盤加載參數(shù),下面具體的相關(guān)介紹,需要的小伙伴可以參考一下2022-03-03selenium+opencv實(shí)現(xiàn)滑塊驗(yàn)證碼的登陸
很多網(wǎng)站登錄登陸時(shí)都要用到滑塊驗(yàn)證碼,本文主要介紹了selenium+opencv實(shí)現(xiàn)滑塊驗(yàn)證碼的登陸,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04三種Python比較兩個(gè)時(shí)間序列在圖形上是否相似的方法分享
這篇文章主要為大家詳細(xì)介紹了三種Python中比較兩個(gè)時(shí)間序列在圖形上是否相似的方法,文中的示例代碼簡(jiǎn)潔易懂,感興趣的小伙伴可以了解一下2023-03-03python常用web框架簡(jiǎn)單性能測(cè)試結(jié)果分享(包含django、flask、bottle、tornado)
這篇文章主要介紹了python常用web框架簡(jiǎn)單性能測(cè)試結(jié)果分享(包含django、flask、bottle、tornado),需要的朋友可以參考下2014-08-08