零基礎學python:錯誤與異常
語法錯誤
異常:大多數的異常都不會被程式處理,都以錯誤資訊的形式展現在這裡
異常處理:
while True:
try:
x = int(input("請輸入一個錯誤:"))
break
except ValueError:
print("不是有效數字,再試一遍")
try 語句執行順序:
- 先執行try語句裡面的語句,如果沒有異常發生,忽略except語句,try子句執行後結束。
- 如果在執行try子句的過程中發生了異常,那麼try子句餘下的部分將被忽略。如果異常的型別和 except 之後的名稱相符,那麼對應的except子句將被執行。
- 如果一個異常沒有與任何的except匹配,那麼這個異常將會傳遞給上層的try中。(try可以巢狀try)
一個except子句可以同時處理多個異常,這些異常將被放在一個括號裡成為一個元組,例如:
except (RuntimeError, TypeError, NameError):
pass
最後一個except子句可以忽略異常的名稱,它將被當作萬用字元使用。你可以使用這種方法列印一個錯誤資訊,然後再次把異常丟擲。
except:
print("作為最後一個,我能捕獲所有之前沒有捕獲的異常")
try except 語句還有一個可選的else子句,如果使用這個子句,那麼必須放在所有的except子句之後。這個子句將在try子句沒有發生任何異常(正常執行)的時候執行。例如:
else:
print("else在正常情況下會被執行")
使用 else 子句比把所有的語句都放在 try 子句裡面要好,這樣可以避免一些意想不到的、而except又沒有捕獲的異常。
異常處理而且還能處理子句中呼叫的函式(甚至間接呼叫的函式)裡丟擲的異常。例如:
except...as err;(err為錯誤型別),as可以返回錯誤型別
''' 學習中遇到問題沒人解答?小編建立了一個Python學習交流群:531509025 尋找有志同道合的小夥伴,互幫互助,群裡還有不錯的視訊學習教程和PDF電子書! ''' def this_fails(): x = 1 / 0 try: this_fails() except ZeroDivisionError as err: print('Handling run-time error:', err) #結果:Handling run-time error: division by zero
finally子句的語句在任何情況下都會被執行
finally:
print("finally在任何情況寫都會被執行")
try-finally語句
語法:
try:
可能觸發異常的語句
finally:
最終語句
說明:finally 子句不可以省略,一定不存在except子句
作用:做必須要做的事情,無論異常是否發生,finally子句都會被執行
注: try-finally語句不會改變程式的(正常/異常)狀態
raise 語句
作用: 觸發一個錯誤,讓程式進入異常狀態
語法:raise 異常型別或raise 異常物件
# #raise 語句
def make_except():
print("開始...")
# raise ZeroDivisionError # 手動發生一個錯誤通知
e = ZeroDivisionError("被零除啦!!!!!")
raise e # 觸發e繫結的錯誤,進入異常狀態
print("結束")
try:
make_except()
print("make_except呼叫完畢!")
except ZeroDivisionError as err:
print('出現了被零除的錯誤,已處理並轉為正常狀態!')
print('err 繫結的物件是:', err)
#開始...
#出現了被零除的錯誤,已處理並轉為正常狀態!
#err 繫結的物件是: 被零除啦!!!!!
assert 斷言語句
語法:assert 真值表達式 , 錯誤資訊(通常是字串)
作用:如果真值表達式為假時,主動的發出異常;如果真值表達式為真,當斷言語句不存在。
assert b==1 # 也可以沒有 異常說明
assert len(lists) >=5,'列表元素個數小於5' # 當len(lists)<5時,主動發出異常
assert b==1,'2不等於1' # 當b不等於1時,主動發出異常,並提示異常
出現使用print()函式打印出記憶體地址的情況,說明你輸出的是列印函式名/模組名/類名,需要用函式把記憶體中的值取出來