本文和大家分享的主要是python3中常見的一些異常及相關(guān)異常處理,一起來看看吧,希望對大家學(xué)習python3有所幫助。 一、什么是異常 異常就是程序運行時發(fā)生錯誤的信號(在程序出現(xiàn)錯誤時,則會產(chǎn)生一個異常,若程序沒有處理它,則會拋出該異常,程序的運行也隨之終止),在Python中,錯誤觸發(fā)的異常如下: 而錯誤分成兩種 #語法錯誤示范一 if #語法錯誤示范二 def test: pass #語法錯誤示范三 class Foo pass #語法錯誤示范四 print(haha 1.語法錯誤(這種錯誤,根本過不了python解釋器的語法檢測,必須在程序執(zhí)行前就改正) #TypeError:int類型不可迭代 for i in 3: pass #ValueError num=input(">>: ") #輸入hello int(num) #NameError aaa #IndexError l=['hello','aa'] l[3] #KeyError dic={'name':'hello'} dic['age'] #AttributeError class Foo:pass Foo.x #ZeroDivisionError:無法完成計算 res1=1/0 res2=1+'str' 2.邏輯錯誤 二、異常的種類 在Python中不同的異??梢杂貌煌念愋?Python中統(tǒng)一了類與類型,類型即類)去標識,一個異常標識一種錯誤 AttributeError 試圖訪問一個對象沒有的樹形,比如foo.x,但是foo沒有屬性x IOError 輸入/輸出異常;基本上是無法打開文件 ImportError 無法引入模塊或包;基本上是路徑問題或名稱錯誤 IndentationError 語法錯誤(的子類) ;代碼沒有正確對齊 IndexError 下標索引超出序列邊界,比如當x只有三個元素,卻試圖訪問x[5] KeyError 試圖訪問字典里不存在的鍵 KeyboardInterrupt Ctrl+C被按下 NameError 使用一個還未被賦予對象的變量 SyntaxError Python代碼非法,代碼不能編譯(個人認為這是語法錯誤,寫錯了) TypeError 傳入對象類型與要求的不符合 UnboundLocalError 試圖訪問一個還未被設(shè)置的局部變量,基本上是由于另有一個同名的全局變量, 導(dǎo)致你以為正在訪問它 ValueError 傳入一個調(diào)用者不期望的值,即使值的類型是正確的 常用異常 ArithmeticError AssertionError AttributeError BaseException BufferError BytesWarning DeprecationWarning EnvironmentError EOFError Exception FloatingPointError FutureWarning GeneratorExit ImportError ImportWarning IndentationError IndexError IOError KeyboardInterrupt KeyError LookupError MemoryError NameError NotImplementedError OSError OverflowError PendingDeprecationWarning ReferenceError RuntimeError RuntimeWarning StandardError StopIteration SyntaxError SyntaxWarning SystemError SystemExit TabError TypeError UnboundLocalError UnicodeDecodeError UnicodeEncodeError UnicodeError UnicodeTranslateError UnicodeWarning UserWarning ValueError Warning ZeroDivisionError 更多異常 三、異常處理 為了保證程序的健壯性與容錯性,即在遇到錯誤時程序不會崩潰,我們需要對異常進行處理, 如果錯誤發(fā)生的條件是可預(yù)知的,我們需要用if進行處理:在錯誤發(fā)生之前進行預(yù)防 AGE=10 while True: age=input('>>: ').strip() if age.isdigit(): #只有在age為字符串形式的整數(shù)時,下列代碼才不會出錯,該條件是可預(yù)知的 age=int(age) if age == AGE: print('you got it') break 如果錯誤發(fā)生的條件是不可預(yù)知的,則需要用到try...except:在錯誤發(fā)生之后進行處理 #基本語法為 try: 被檢測的代碼塊 except 異常類型: try中一旦檢測到異常,就執(zhí)行這個位置的邏輯 #舉例 try: f=open('a.txt') g=(line.strip() for line in f) print(next(g)) print(next(g)) print(next(g)) print(next(g)) print(next(g)) except StopIteration: f.close() #1 異常類只能用來處理指定的異常情況,如果非指定異常則無法處理。 s1 = 'hello' try: int(s1) except IndexError as e: # 未捕獲到異常,程序直接報錯 print e #2 多分支 s1 = 'hello' try: int(s1) except IndexError as e: print(e) except KeyError as e: print(e) except ValueError as e: print(e) #3 萬能異常Exception s1 = 'hello' try: int(s1) except Exception as e: print(e) #4 多分支異常與萬能異常 #4.1 如果你想要的效果是,無論出現(xiàn)什么異常,我們統(tǒng)一丟棄,或者使用同一段代碼邏輯去處理他們,那么騷年,大膽的去做吧,只有一個Exception就足夠了。 #4.2 如果你想要的效果是,對于不同的異常我們需要定制不同的處理邏輯,那就需要用到多分支了。 #5 也可以在多分支后來一個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) #6 異常的其他機構(gòu) 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)代碼塊沒有異常則執(zhí)行我') finally: print('無論異常與否,都會執(zhí)行該模塊,通常是進行清理工作') #7 主動觸發(fā)異常 try: raise TypeError('類型錯誤') except Exception as e: print(e) #8 自定義異常 class EgonException(BaseException): def __init__(self,msg): self.msg=msg def __str__(self): return self.msg try: raise EgonException('類型錯誤') except EgonException as e: print(e) #9 斷言:assert 條件 assert 1 == 1 assert 1 == 2 #10 總結(jié)try..except 1:把錯誤處理和真正的工作分開來 2:代碼更易組織,更清晰,復(fù)雜的工作任務(wù)更容易實現(xiàn); 3:毫無疑問,更安全了,不至于由于一些小的疏忽而使程序意外崩潰了; View Code 來源:網(wǎng)絡(luò) |