在編寫Python代碼或開發(fā)實際應(yīng)用的項目時,程序報出異常或錯誤是在所難免的,那么我們應(yīng)該怎樣處理這些異常呢?下面來說一下方法。
1.使用try...except捕捉異常
try:
s=1/0
exceptIndexError:
print('except')
exceptKeyError:
print('Keyerror')
exceptZeroDivisionError:
print('ZeroDivisionError')
或
try:
s=1/0
except:
print('出現(xiàn)異常')
或有多個異常名稱的格式
try:
s=1/0
except(IndexError,KeyError,ZeroDivisionError),e:
print(e)
2.使用try...except...else語句捕捉異常
當(dāng)try塊中的代碼沒有異常時,則跳過except塊中的代碼,執(zhí)行else塊中的代碼
工作原理:
1).如果try代碼塊語句執(zhí)行發(fā)生異常,Python就跳回try,執(zhí)行第一個匹配該異常的except塊中的代碼
2).如果異常發(fā)生在try代碼塊內(nèi),沒有匹配的except子句,name異常就會向上傳遞到程序中之前進(jìn)入的try中,或者轉(zhuǎn)到這個進(jìn)程的頂層(這會使python終止當(dāng)前程序并打印默認(rèn)的錯誤消息)
3).如果try塊中的代碼執(zhí)行沒有異常發(fā)生,則python將執(zhí)行else塊中的代碼
3.使用try...finally捕捉異常
當(dāng)try塊中包含了finally語句,則python一定會在執(zhí)行完try塊中的代碼之后在執(zhí)行finally塊中的代碼(無論try塊中的代碼是否發(fā)生異常都將執(zhí)行finally塊中的代碼)
工作原理:
1).如果執(zhí)行try塊中的代碼時沒有發(fā)生異常,則Python會跳轉(zhuǎn)至finally語句并執(zhí)行該代碼塊,然后繼續(xù)執(zhí)行程序中finally語句之后的代碼
2).如果執(zhí)行try塊中的代碼時發(fā)生異常,則Python依然會執(zhí)行finally語句中的代碼塊,但是接著會將異常向上傳遞到上層的try語句或頂層的默認(rèn)處理器,程序不會繼續(xù)執(zhí)行導(dǎo)致發(fā)生異常的語句之后的try塊中的代碼。也就是說,即使發(fā)生了異常,finally代碼塊還是會被執(zhí)行,和except不同的是,finally不會終止異常,而是在finally代碼塊執(zhí)行后,一直處于發(fā)生狀態(tài)
4.使用raise拋出異常(手工引發(fā)異常)
raise<異常對象>
‘異常對象’表示將引發(fā)異常的異常名稱,且異常名稱標(biāo)識了具體的異常類。raise語句還可指定對異常對象進(jìn)行初始化的參數(shù),為此需要在異常類的名稱后添加一個逗號以及指定參數(shù)(或者由參數(shù)構(gòu)成的一個元組)。一旦執(zhí)行了raise語句,raise語句后的代碼將不能被執(zhí)行
raise<異常對象>,<異常信息標(biāo)識>
例子:
try:
raiseNameError
exceptNameError:
print('拋出一個異常')
5.自定義異常
格式classMyError(Exception):
def__init__(self,value):
self.value=value
def__str__(self):
returnrepr(self.value)
try:
raiseMyError(2*2)
exceptMyErrorase:
print('Myexceotionoccurred,value:',e.value)
6.使用assert語句
用于檢測某個條件表達(dá)式是否為真。又稱斷言語句,即assert認(rèn)為檢測的表達(dá)式永遠(yuǎn)為真,斷言失敗就會引發(fā)AssertionError異常
語法格式:assert<條件判斷表達(dá)式>
username='admin'
password='123456'
assertusername=='admin'andpassword=='admin','密碼錯誤!
以上內(nèi)容為大家介紹了python培訓(xùn)之報的錯誤怎么處理,希望對大家有所幫助,如果想要了解更多Python相關(guān)知識,請關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。