Python異常原理及異常捕捉實(shí)現(xiàn)過程解析
關(guān)于選課程序,最近著實(shí)有點(diǎn)忙,沒機(jī)會(huì)復(fù)習(xí)os、pickle兩部分模塊,所以數(shù)據(jù)儲(chǔ)存和字典讀取成為了一個(gè)問題,大致原理知道,但是具體操作可能還是得返回去再好好看看,所以目前就提前開始學(xué)習(xí)新的知識(shí)了,雖然今天感覺str的相關(guān)方法忘的是干干凈凈的,但是我有pycharm。
今天主要內(nèi)容是關(guān)于異常,其實(shí)有點(diǎn)想最開始剛學(xué)的感覺,比較簡(jiǎn)單。
異常就是程序運(yùn)行時(shí)發(fā)生錯(cuò)誤的信號(hào)(在程序出現(xiàn)錯(cuò)誤時(shí),則會(huì)產(chǎn)生一個(gè)異常,若程序沒有處理它,則會(huì)拋出該異常,程序的運(yùn)行也隨之終止),在python中,錯(cuò)誤觸發(fā)的異常如下:
錯(cuò)誤被分為了兩種:
1.語法錯(cuò)誤,基本pycharm都會(huì)幫你顯示出來,不該犯的
2.邏輯錯(cuò)誤,不太容易看出來,pycharm也不管,只有Python解釋器是真愛,但是也得等到真的運(yùn)行的時(shí)候
#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:無法完成計(jì)算 res1=1/0 res2=1+'str'
下面是今天最為重要的部分:
在python中不同的異常可以用不同的類型(python中統(tǒng)一了類與類型,類型即類)去標(biāo)識(shí),一個(gè)異常標(biāo)識(shí)一種錯(cuò)誤
AttributeError 試圖訪問一個(gè)對(duì)象沒有的樹形,比如foo.x,但是foo沒有屬性x
IOError 輸入/輸出異常;基本上是無法打開文件
ImportError 無法引入模塊或包;基本上是路徑問題或名稱錯(cuò)誤
IndentationError 語法錯(cuò)誤(的子類) ;代碼沒有正確對(duì)齊
IndexError 下標(biāo)索引超出序列邊界,比如當(dāng)x只有三個(gè)元素,卻試圖訪問x[5]
KeyError 試圖訪問字典里不存在的鍵
KeyboardInterrupt Ctrl+C被按下
NameError 使用一個(gè)還未被賦予對(duì)象的變量
SyntaxError Python代碼非法,代碼不能編譯(個(gè)人認(rèn)為這是語法錯(cuò)誤,寫錯(cuò)了)
TypeError 傳入對(duì)象類型與要求的不符合
UnboundLocalError 試圖訪問一個(gè)還未被設(shè)置的局部變量,基本上是由于另有一個(gè)同名的全局變量,
導(dǎo)致你以為正在訪問它
ValueError 傳入一個(gè)調(diào)用者不期望的值,即使值的類型是正確的
更多異常(有空還是要挨個(gè)錯(cuò)一遍):
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
為了保證程序的健壯性與容錯(cuò)性,即在遇到錯(cuò)誤時(shí)程序不會(huì)崩潰,我們需要對(duì)異常進(jìn)行處理,
如果錯(cuò)誤發(fā)生的條件是可預(yù)知的,我們需要用if進(jìn)行處理:在錯(cuò)誤發(fā)生之前進(jìn)行預(yù)防
之前也是有操作過的:
AGE=10 while True: age=input('>>: ').strip() if age.isdigit(): #只有在age為字符串形式的整數(shù)時(shí),下列代碼才不會(huì)出錯(cuò),該條件是可預(yù)知的 age=int(age) if age == AGE: print('you got it') break
如果錯(cuò)誤發(fā)生的條件是不可預(yù)知的,則需要用到try...except:在錯(cuò)誤發(fā)生之后進(jìn)行處理
#基本語法為 try: 被檢測(cè)的代碼塊 except 異常類型: try中一旦檢測(cè)到異常,就執(zhí)行這個(gè)位置的邏輯 #舉例 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: # 未捕獲到異常,程序直接報(bào)錯(cuò) 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)一丟棄,或者使用同一段代碼邏輯去處理他們,那么騷年,大膽的去做吧,只有一個(gè)Exception就足夠了。 #4.2 如果你想要的效果是,對(duì)于不同的異常我們需要定制不同的處理邏輯,那就需要用到多分支了。 #5 也可以在多分支后來一個(gè)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 異常的其他機(jī)構(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('無論異常與否,都會(huì)執(zhí)行該模塊,通常是進(jìn)行清理工作') #7 主動(dòng)觸發(fā)異常 try: raise TypeError('類型錯(cuò)誤') 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('類型錯(cuò)誤') except EgonException as e: print(e) #9 斷言:assert 條件 assert 1 == 1 assert 1 == 2 #10 總結(jié)try..except
異常捕捉的優(yōu)勢(shì):
1:把錯(cuò)誤處理和真正的工作分開來
2:代碼更易組織,更清晰,復(fù)雜的工作任務(wù)更容易實(shí)現(xiàn);
3:毫無疑問,更安全了,不至于由于一些小的疏忽而使程序意外崩潰了;
主要是理論知識(shí),后期使用才是關(guān)鍵,就像我要復(fù)習(xí)的pickle和os模塊一樣,就是這些了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
基于Python實(shí)現(xiàn)蒙特卡洛法計(jì)算圓周率π
蒙特卡羅法也稱統(tǒng)計(jì)模擬法、統(tǒng)計(jì)試驗(yàn)法,是把概率現(xiàn)象作為研究對(duì)象的數(shù)值模擬方法,是按抽樣調(diào)查法求取統(tǒng)計(jì)值來推定未知特性量的計(jì)算方法,本文我們將介紹如何使用Python來實(shí)現(xiàn)蒙特卡洛法計(jì)算圓周率π,感興趣的朋友可以參考下2023-06-06python類中super()和__init__()的區(qū)別
這篇文章主要介紹了python類中super()和__init__()的區(qū)別,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2016-10-10手把手教你實(shí)現(xiàn)PyTorch的MNIST數(shù)據(jù)集
本文主要介紹了PyTorch的MNIST數(shù)據(jù)集,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-06-06opencv 實(shí)現(xiàn)特定顏色線條提取與定位操作
這篇文章主要介紹了opencv 實(shí)現(xiàn)特定顏色線條提取與定位操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-06-06Python正則表達(dá)式常用函數(shù)總結(jié)
這篇文章主要介紹了Python正則表達(dá)式常用函數(shù),結(jié)合實(shí)例形式總結(jié)分析了Python正則表達(dá)式常用函數(shù)功能、使用方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-06-06pandas去除重復(fù)列的實(shí)現(xiàn)方法
這篇文章主要介紹了pandas去除重復(fù)列的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01