Python中try...except...finally的理解

简介: 首先我们打开一个不存在的文件: fp = open("null.txt","r") 然后提示报错如下:---------------------------------------------------------------------------IOError ...

首先我们打开一个不存在的文件:

 fp = open("null.txt","r")

然后提示报错如下:
---------------------------------------------------------------------------
IOError                                   Traceback (most recent call last)
<ipython-input-3-f70973547c7e> in <module>()
----> 1 fp = open("null.txt","r")

IOError: [Errno 2] No such file or directory: 'null.txt'


接着我们使用try...except...来执行这条语句

In [4]: try:
   ...:     fp = open("null.txt","r")
   ...: except:
   ...:     print "open error"
   ...:     
open error



接着我们再在后面加一条finally语句,所谓的filally就是最后要执行的,它不管你前边是否发送错误
In [4]: try:
   ...:     fp =open('null.txt','r')
   ...: except:
   ...:     print 'opoen error'
   ...: finally:
   ...:     print 'end'
   ...:     
opoen error
end

    

接着我们使用except打印出错误类型,然后观察错误的type

In [5]: try:
   ...:     fp = open('null.txt','r')
   ...: except Exception,e:
   ...:     print e
   ...:     print type(e)
   ...:     
[Errno 2] No such file or directory: 'null.txt'
<type 'exceptions.IOError'>

我们可以看到except把错误捕捉到赋值给e,然后将其打印出,可以看到为IOError,所以在这里我们可以修改上边为:


In [9]: try:
   ...:     fp = open('null.txt', 'r')
   ...: except IOError,e:
   ...:     print "ioerror"
   ...:     
ioerror

当然这里如果不是IOError的话,上边except语句是捕捉不到的,例如:

In [10]: try:
   ....:     a = 10/0
   ....: except IOError,e:
   ....:     print "ioerror"
   ....:     
---------------------------------------------------------------------------
ZeroDivisionError                         Traceback (most recent call last)
<ipython-input-10-e17eff88239d> in <module>()
      1 try:
----> 2     a = 10/0
      3 except IOError,e:
      4     print "ioerror"
      5 

ZeroDivisionError: integer division or modulo by zero

这时我们需要另外的错误类型进行捕获,例如:


In [11]: try:
   ....:     a = 10/0
   ....: except IOError,e:
   ....:     print "IOError"
   ....: except ZeroDivisionError,e:
   ....:     print "Zero Error"
   ....:     
Zero Error
可以看到第一个except并没有捕捉到错误,所以传给下一个except,当然如果所有的except都没有捕获到的话,程序就会抛出异常

在这里我们不得不注意的是,python的错误类型其实都是class,所有的错误类型都继承自BaseException,所以在使用except时需要注意的是,它不但捕获该类型的错误,还把其子类也“一网打尽”。比如:

In [14]: try:
   ....:     a = 10 /0
   ....: except StandardError,e:
   ....:     print 'standardError'
   ....: except ZeroDivisionError,e:
   ....:     print 'zero error'
   ....:     
standardError

第二个 except永远也捕获不到 ValueError,因为 ZeroDivisionErrorStandardError的子类,如果有,也被第一个 except给捕获了。

使用try...except...finally的另外一个好处是,可以跨越多层调用,例如:

In [15]: def foo(m):
   ....:     return 10/int(m)
   ....: 

In [16]: def goo():
   ....:     a = "0"
   ....:     foo(a)
   ....:     

In [17]: def main():
   ....:     goo()
   ....:     

In [18]: try:
   ....:     main()
   ....: except Exception,e:
   ....:     print e
   ....:     
integer division or modulo by zero

在foo()函数中抛出的错误,然而在goo和main函数中都没有进行捕捉,在执行main函数时进行捕获,也可以捕获到


除了try...except...finally之外还有python的logging模块,也可以进行错误调试,当然我们也可以使用raise抛出异常

相关文章
|
4月前
|
数据库连接 Python
Python中的异常处理除了Try语句,你还会啥?
Python中的异常处理除了Try语句,你还会啥?
68 1
|
4月前
|
Python
|
4月前
|
Python
Python 中的 try 和 except 块
【8月更文挑战第29天】
56 6
|
6月前
|
开发者 Python
在Python中,异常处理通过`try`、`except`、`else`和`finally`关键字进行
【6月更文挑战第26天】在Python中,异常处理通过`try`、`except`、`else`和`finally`关键字进行。基本结构包括尝试执行可能抛出异常的代码,然后指定`except`来捕获特定或任何类型的异常。`else`块在`try`无异常时执行,`finally`块确保无论是否发生异常都会执行,例如用于清理。可以使用`raise`重新抛出异常,而自定义异常则允许创建特定的错误类。这种机制增强了代码的健壮性。
77 7
|
6月前
|
定位技术 Python
Python的try、except异常处理模块使用方法
所以,我们就解决了由于可能具有的arcpy.ExecuteError异常而导致的程序中断问题;大家在实际使用时,按照自己程序中可能出现的报错类,对本文出现的arcpy.ExecuteError异常类加以修改即可。
|
7月前
|
Python
python的else块(可选)在try块成功执行且没有引发异常时执行
【5月更文挑战第12天】python的else块(可选)在try块成功执行且没有引发异常时执行
67 1
|
7月前
|
Python
|
7月前
|
存储 开发者 Python
Python从入门到精通:2.2.1异常处理与文件操作——学习try/except语句进行异常处理
Python从入门到精通:2.2.1异常处理与文件操作——学习try/except语句进行异常处理
141 3
|
7月前
|
Python
python中的异常处理(try,except,else, finally)
python中的异常处理(try,except,else, finally)
82 0
|
Python
Python--一言不合就try一下?
Python--一言不合就try一下?
58 0