异常处理
异常处理语句用来检测try语句中的错误,从而让except语句捕获错误信息并处理。
try...except 错误码 as e...else
格式
try:
语句t
except 错误码 as e:
语句1
except 错误码 as e:
语句2
......
except 错误码 as e:
语句N
else: # else语句可有可无
语句e
当try语句中出现错误时,会按照顺序匹配except中的错误码,如果匹配上就执行对应语句;如果没有匹配到错误码,则会被提交到上一层的try语句,或者到程序的最上层。
当try语句中没有错误,并且存在else语句,则执行else下的语句e。
try:
print(3 / 0)
except NameError as e:
print("变量不存在!")
except ZeroDevisionError as e:
print("除数不能为零!")
else:
print("程序执行成功!")
需要注意的是:
1.错误其实是类(class),所有的错误都继承自BaseException,因此只要捕获了父类BaseException,也就捕获了所有错误。当父类的except语句在子类的except语句之前,则捕获父类之后,子类不会再被捕获到;反之亦然。
2.跨越多层调用,可以被最外层程序捕获到错误。
def func1(num):
print(3 / num)
def func2(num):
func1(num)
def main():
func2(0)
try:
main()
except ZeroDivisionError as e:
print("除数不能为零!") # 跨越多层调用,可以在外层捕获到错误
try...except
try:
print(3 / 0)
except:
print("程序出错!")
except不携带错误码,程序执行结果无法显示错误原因 。
try...except(错误码列表)
try:
print(3 / 0)
except (NameError, ZeroDivisionError):
print("出现NameError或ZeroDivisionError异常!")
try...except...finally
无论try语句内容是否存在异常,finally始终被执行,常用于恢复程序状态。
断言
assert <expression> , <ErrorLogString>
def func(num, div):
assert (div != 0), "div不能为0!"
return num / div
使用断言替代print打印来调试代码的好处是:断言可以被关闭,终端或IDE可以设置断言失效。