\IOError: [Errno 2] No such file or directory: 'abc.txt'
打开一个不存在的文件abc.txt 文件,当系统找不到abc.txt 文件时,就会抛出给我们一个IOError类型的错误,No such file or directory:abc.txt (没有abc.txt这样的文件或目录)
Try...except...
假如,我们已经知道这种类型的错误,那么就可以通过一个异常扑捉来扑捉这个错误。我们可以通过try...except 来接收这个错误。打开文件写入: try:
open(\"abc.txt\except IOError: pass
再来运行程序就会看不到任何错误,因为我们用except 接收了这个IOError错误。pass 表示实现了相应的实现,但什么也不做。
假如我不是打开一个文件,而是输出一个没有定义的变量呢? try:
print aa except IOError: pass
显然,在上面的代码中我并没有对aa 赋值,运行结果:
Traceback (most recent call last):
File \"/home/fnngj/py_se/tryy.py\ print aa
NameError: name 'aa' is not defined
我们已经用except 接收错误了,为什么错误还是还是抛出来了。如果你细心会发现这一次的错误类型是NameError ,而我接收类型是IOError ,所以要想接收这个print的错误,那么需要修改接收错误的类型为NameError
虽然,我知道print 语句是可能会抛一个NameError 类型的错误,虽然接收了这个类型错误,但我不知道具体的错误提示信息是什么。那么,我能不能把错误信息打印出来呢?当然可以: try:
print aa
except NameError, msg: print msg
我们在接收错误类型的后面定义一个变量msg用于接收具体错误信息, 然后将msg接收的错误信息打印。再来运行程序:
name 'aa' is not defined
现在只打印了一行具体错误信息。
异常的抛出机制:
1、如果在运行时发生异常,解释器会查找相应的处理语句(称为handler).
2、要是在当前函数里没有找到的话,它会将异常传递给上层的调用函数,看看那里能不能处理。 3、如果在最外层(全局“main”)还是没有找到的话,解释器就会退出,同时打印出traceback以便让用户找到错误产生的原因。
注意:虽然大多数错误会导致异常,但一个异常不一定代表错误,有时候它们只是一个警告,有时候它们可能是一个终止信号,比如退出循环等。
try...finally...
try...finally...子句用来表达这样的情况:
我们不管线捕捉到的是什么错误,无论错误是不是发生,这些代码“必须”运行,比如文件关闭,释放锁,把数据库连接返还给连接池等。
创建文件poem.txt
tryf.py 复制代码
import time try:
f = file('poem.txt')
while True: # our usual file-reading idiom line = f.readline() if len(line) == 0: break time.sleep(2) print line,
finally:
f.close()
print 'Cleaning up...closed the file'
复制代码
运行程序(在windows命令提示符或linux终端下运行): 复制代码
...$ python tryf.py abc efg
^CCleaning up...closed the file Traceback (most recent call last): File \"tryy.py\ time.sleep(2) KeyboardInterrupt
复制代码
程序读poem.txt文件中每一行数据打印,但是我有意在每打印一行之前用time.sleep方法暂停2秒钟。这样做的原因是让程序运行得慢一些。在程序运行的时候,按Ctrl-c中断/取消程序。
我们可以观察到KeyboardInterrupt异常被触发,程序退出。但是在程序退出之前,finally从句仍然被执行,把文件关闭。
到目前为止,我们只讨论了如何捕捉异常,那么如何抛出异常呢?
Raise抛出异常
使用raise来抛出一个异常:
tryr.py
#coding=utf-8
filename = raw_input('please input file name:')
if filename=='hello':
raise NameError('input file name error !')
程序要求用户输入一个文件名,如果用户输入的文件名是hello ,那么抛出一个NameError的异常,用户输入hello 和NameError异常之间没有任何必然联系,我只是人为的通过raise来这样定义,我当然也可以定义称TypeError ,但我定义的异常类型必须是python提供的。
附录:
常见的python异常类型
从几年前开始学习编程直到现在,一直对程序中的异常处理怀有恐惧和排斥心理。之所以这样,是因为不了解。这次攻python,首先把自己最畏惧和最不熟悉的几块内容列出来,里面就有「异常处理」这一项。
《Dive into Python》并没有专门介绍异常处理,只是例子中用到的时候略微说明了一下。今天下载《Learn Python》,直接进异常处理这块。这一部分有四章,第一章讲解异常处理的一般使用方法,后面的章节深入地讨论其机制。我目前只看了第一章,先学会用,以后有必要的时候再扩展阅读。
python主要支持五种异常机制,一一列举。
默认的异常处理器
复制代码 代码如下:
s = 'Hello girl!' print s[100] print 'continue'
如果我们没有对异常进行任何预防,那么在程序执行的过程中发生异常,就会中断程序,调用python默认的异常处理器,并在终端输出异常信息。这种情况下,第3行代码不会执行。
try…except
复制代码 代码如下:
s = 'Hello girl!' try:
print s[100]
except IndexError: print 'error...' print 'continue'
程序执行到第2句时发现try语句,进入try语句块执行,发生异常,回到try语句层,寻找后面是否有except语句。找到except语句后,会调用这个自定义的异常处理器。except将异常处理完毕后,程序继续往下执行。这种情况下,最后两个print语句都会执行。
except后面也可以为空,表示捕获任何类型的异常。
try…finally
复制代码 代码如下:
s = 'Hello girl!' try:
print s[100] finally:
print 'error...' print 'continue'
finally语句表示,无论异常发生与否,finally中的语句都要执行。但是,由于没有except处理器,finally执行完毕后程序便中断。这种情况下,倒第2个print会执行,到第1个不会执行。如果try语句中没有异常,三个print都会执行。
assert
复制代码 代码如下:
assert False,'error...' print 'continue'
这个语句,先判断assert后面紧跟的语句是True还是False,如果是True则继续执行print,如果是False则中断程序,调用默认的异常处理器,同时输出assert语句逗号后面的提示信息。本例情况下,程序中断,提示error,后面的print不执行。
with…as
复制代码 代码如下:
with open('nothing.txt','r') as f: f.read() print 2/0
print 'continue'
我们平时在使用类似文件的流对象时,使用完毕后要调用close方法关闭,很麻烦。这里with„as语句提供了一个非常方便的替代方法:open打开文件后将返回的文件流对象赋值给f,然后在with语句块中使用。with语句块完毕之后,会隐藏地自动关闭文件。
如果with语句或语句块中发生异常,会调用默认的异常处理器处理,但文件还是会正常关闭。
这种情况下,会抛出异常,最后的print不执行。
书中介绍的很详细,除了上面我提到的之外,还有很多有用的附加信息,比如try..except..finally..else可以连用,比如自定义异常类。这里不再列出,详情可以参考这本书中的介绍。
python异常如何全面捕获
标签: pythonexceptionimportfilec
2012-04-04 13:38 19728人阅读 评论(1) 收藏 举报 分类:
Python(11)
版权声明:本文为博主原创文章,未经博主允许不得转载。
如果你在写程序时遇到异常后想进行如下处理的话请参考我下面写的对异常处理的方法:
假设有下面的一段程序: try:
语句1 语句2 .
语句N except .........: print .......
但是你并不知道“语句1至语句N”在执行会出什么样的异常,但你还要做异常处理,且想把出现的异常打印出来,并不停止程序的运行, 所以在“except ......”这句应怎样来写呢? 至少3个方法:
方法一:捕获所有异常
[python] view plaincopyprint?
try:
a=b b=c
except Exception,ex:
print Exception,\":\
方法二:采用traceback模块查看异常
[python] view plaincopyprint?
import traceback try:
a=b b=c except:
traceback.print_exc()
方法三:采用sys模块回溯最后的异常
[python] view plaincopyprint?
import sys try:
a=b b=c except:
info=sys.exc_info() print info[0],\":\
但是,如果你还想把这些异常保存到一个日志文件中,来分析这些异常,那么请看下面的方法:
把 traceback.print_exc() 打印在屏幕上的信息保存到一个文本文件中
[python] view plaincopyprint?
try:
a=b b=c except:
f=open(\"c:log.txt\ traceback.print_exc(file=f) f.flush() f.close()
python中的异常
异常是指程序中的例外,违例情况。异常机制是指程序出现错误后,程序的处理方法。当出现错误后,程序的执行流程发生改变,程序的控制权转移到异常处理。
Exception类是常用的异常类,该类包括StandardError,StopIteration, GeneratorExit, Warning等异常类。
StandardError类是python中的错误异常,如果程序上出现逻辑错误, 将引发该异常。StandardError类是所有内敛异常的基类,放置在默认的命名空间中,因此使用IOEroor, EOFError, ImportError等类,不需要导入exception模块。
StopIteration类判断循环是否执行到尾部,如果循环到尾部,则抛出该异常。
GeneratorExit类是由Generator函数引发的异常,当调用close()时引发该异常。 Warning类表示程序中的代码引起的警告。
python中的异常使用继承结构创建,可以在异常处理程序中捕获基类异常,也可以捕获各种子类异常,python中使用try...except语句捕获异常,异常子句定义在try子句后面。
try...except的使用方法
try...except用于处理问题语句,捕获可能出现的异常。try子句中的代码块放置可能出现异常的语句,except子句中的代码块处理异常。 演示try...except语句捕获IOError异常 try:
file(\"hello.txt\ #如果文件不存在,引发异常 print \"读文件\"
except IOError: #捕获IO异常 print \"文件不存在\"
except: #其它异常 print \"程序异常\"
python与Java的异常处理模式相似,异常处理语句也可以嵌套,演示如下: try:
s = \"hello\" try:
print s[0] + s[1] print s[0] - s[1] except TypeError:
print \"字符串不支持减法运算\"
except:
print \"异常\"
如果外层try子句中的代码引发异常,程序将直接跳转到外层try对应的except子句,而内部的try子句将不会被执行。
try...finally的使用方法
try...except后还可以添加一个finally子句。无论异常是否发生,finally子句都会被执行。所有的finally子句通常用于关闭因异常而不能释放的系统资源。 try:
f = open(\"hello.txt\ try:
print f.read(5) except:
print \"读文件异常\" finally:
print \"释放资源\" f.close() except IOError:
print \"文件不存在\"
使用raise抛出异常
当程序出现错误,python会自动引发异常,也可以通过raise显示地引发异常。一旦执行了raise语句,raise后面的语句将不能执行。 演示raise用法 try:
s = None if s is None:
print \"s 是空对象\"
raise NameError #如果引发NameError异常,后面的代码将不能执行 print len(s) except TypeError:
print \"空对象没有长度\"
自定义异常
python允许程序员自定义异常,用于描述python中没有涉及的异常情况,自定义异常必须继承Exception类,自定义异常按照命名规范以\"Error\"结尾,显示地告诉程序员这是异常。自定义异常使用raise语句引发,而且只能通过人工方式触发。 from __future__ import division
class DivisionException(Exception): def __init__(self, x, y):
Exception.__init__ (self, x, y) #调用基类的__init__进行初始化 self.x = x self.y = y
if __name__ == \"__main__\": try:
x = 3 y = 2
if x % y > 0: #如果大于0, 则不能被初始化,抛出异常
print x/y
raise DivisionException(x, y)
except DivisionException,div: #div 表示DivisionException的实例对象 print \"DivisionExcetion: x/y = %.2f\" % (div.x/div.y)
assert语句的使用
assert语句用于检测某个条件表达式是否为真。assert语句又称为断言语句,即assert认为检测的表达式永远为真,if语句中的条件判断都可以使用assert语句检测。