語法錯誤
例外:大多數的例外都不會被程式處理,都以錯誤資訊的形式展現在這里
例外處理:
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()函式列印出記憶體地址的情況,說明你輸出的是列印函式名/模塊名/類名,需要用函式把記憶體中的值取出來
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/296020.html
標籤:Python
