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中不同的異??梢杂貌煌念愋停╬ython中統(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使用Rich實(shí)現(xiàn)美化終端顯示效果
Rich庫(kù)的功能就像它的名字一樣,使Python編程更加豐富(rich),用來幫助開發(fā)者在控制臺(tái)(命令行)輸出中創(chuàng)建豐富、多彩和具有格式化的文本,下面我們就來了解下它的具體使用吧2024-02-02
解決plt.savefig()和plt.show()方法得到的圖片不一樣問題
這篇文章主要介紹了解決plt.savefig()和plt.show()方法得到的圖片不一樣問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
Python 快速驗(yàn)證代理IP是否有效的方法實(shí)現(xiàn)
有時(shí)候,我們需要用到代理IP,比如在爬蟲的時(shí)候,不知道怎么驗(yàn)證這些IP是不是有效的,本文就介紹一下,感興趣的可以了解一下2021-07-07
Python?Poetrya項(xiàng)目依賴管理安裝使用詳解
這篇文章主要為大家介紹了Python?Poetrya項(xiàng)目依賴管理安裝使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11
django的模型類管理器——數(shù)據(jù)庫(kù)操作的封裝詳解
這篇文章主要介紹了django的模型類管理器——數(shù)據(jù)庫(kù)操作的封裝詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-04-04
python?中的requirements.txt?文件的使用詳情
這篇文章主要介紹了python?中的requirements.txt文件的使用詳情,文章圍繞主題展開詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-05-05

