龙空技术网

这一篇就够了!带你全面了解Python的异常处理机制

ZeekerLab 192

前言:

如今各位老铁们对“python文件异常”都比较珍视,小伙伴们都需要了解一些“python文件异常”的相关知识。那么小编在网络上搜集了一些对于“python文件异常””的相关知识,希望姐妹们能喜欢,各位老铁们快快来了解一下吧!

Python的异常机制主要依赖try、except、else、finally和raise五个关键字,其中在try关键字后缩进的代码块简称try块,它里面放置的是可能引发异常的代码;在except后对应的是异常类型和一个代码块,用于表明该except块处理这种类型的代码;在多个except块之后可以放一个else块,表明程序不出现异常时还要执行else块;最后还可以跟一个finally块,finally块用于回收在try块里打开的物理资源,异常机制会保证finally块总被执行;而raise用于引发一个实际的异常,raise可以单独作为语句使用,引发一个具体的异常对象。

Python的异常处理机制可以让程序具有极好的容错性,让程序更加健壮,当程序运行出现意外情况时,系统会自动生成一个Error对象来通知程序,从而实现将“业务实现代码”和“错误处理代码”分离,提供更好的可读性。

使用try...except捕获异常

try

#业务实现代码

...

except (Error1, Error2, …) as e:

alert 输入不合法

goto retry

如果在执行try块里的业务逻辑代码出现异常,系统自动生成一个异常对象,该异常对象被提交给Python解释器,这个过程称为引发异常。

当Python解释器收到异常对象时,会寻找能处理该异常对象的except块,如果找到合适的except块,则把该异常对象交给该except块处理,这个过程被称为捕获异常。如果Python解释器找不到捕获异常的except块,则运行时环境终止,Python解释器也将退出。

异常类的继承体系

当Python解释器接收到异常对象时,会依次判断该异常是否为except块后的异常类或其子类的实例,如果是,Python解释器将调用该except块来处理该异常;否则,再次拿该异常对象和下一个except块里的异常类进行比较。

通过在try块后提供多个except块可以额无须在异常处理块中使用if判断异常类型,但依然可以针对不同的异常类型提供相应的处理逻辑,从而提供更细致、更有条理的异常处理逻辑。

Python的所有异常类都是从BaseException派生而来,提供了丰富的异常类,这些异常类之间有严格的继承关系。

可以看出,Python的所有异常类的基类都是BaseException,如果你要实现自定义异常,则不应该继承这个类,而是应该继承Exception类。

BaseException的主要子类就是Exception,不管是系统的异常类,还是用户自定义的异常类,都应该从Exception派生。

上面程序中,导入了sys模块,并通过sys模块的argv列表来获取运行Python程序时提供的参数。其中,sys.argv[0]代表正在运行的Python程序名,sys.argv[1]代表运行程序所提供的第一个参数,sys.argv[2]代表运行程序所提供的第二个参数, ...以此类推。

在此,提个问题:为什么上面程序把对应Exception类的except块放在最后呢?

通过前面Python的异常类的继承关系图可以知道,如果把Exception类对应的except块排在其他except块的前面,Python解释器将直接进入该except块,因为所有的异常对象都是Exception或其子类的实例,而排在它后面的except块将永远无法获得执行的机会。

实际上,在进行异常捕获时,不仅应该把Exception类对应的except块放在最后,而且所有父类异常的except块都应该排在子类异常的except块的后面,即先处理小异常,再处理大异常。

多异常捕获访问异常信息

如果程序需要在except块中访问异常对象的相关信息,则可通过为异常对象声明变量来实现。

当Python解释器决定调用某个except块来处理该异常对象时,会将异常对象赋值给except块后面的异常变量,程序即可通过该变量来获得异常对象的相关信息。

所有的异常对象都包含如下几个常用的属性和方法:

1. args:该属性返回异常的错误编号和描述字符串

2. errno:该属性返回异常的错误编号

3. strerror:该属性返回异常的描述字符串

4. with_traceback():该方法可处理异常的传播轨迹信息

使用finally回收资源

有些时候,程序在try块里打开了一些物理资源(如数据库连接、网络连接和磁盘文件等),这些资源都必须被显示回收。

那么该在哪里回收呢?为了保证能回收try块中打开的物理资源,异常处理机制提供了finally块,因此不管try块中的代码是否出现了异常,也不管哪一个except块被执行,甚至在try块或except块中执行了return语句,finally块总会被执行。

注意,在异常处理结构中,只有try块是必需的,except块和finally块是可选的,但except块和finally块至少出现其中之一,也可以同时出现,不能只有try块,既没有except块也没有finally块,且finally块必须位于所有except块之后。

说明:除非在try块、except块中调用了退出Python解释器的方法(如sys.exit()等),否则不管在try块、except块中执行怎样的代码,出现怎样的情况,异常处理的finally块总会被执行。

另外需注意:不要在finally块中使用如return或raise等导致方法终止的语句,一旦在finally块中使用了return或raise语句,将会导致try块、except块中的return、raise语句失效。

如下示例中,因为finally块中使用了return语句,则try块中的return语句失效了:

标签: #python文件异常 #pythonexceptraise