python异常处理和断言

异常处理

异常处理语句用来检测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可以设置断言失效。

猜你喜欢

转载自blog.csdn.net/u010378984/article/details/82731294