码迷,mamicode.com
首页 > 编程语言 > 详细

python 异常断言

时间:2017-02-04 16:48:12      阅读:301      评论:0      收藏:0      [点我收藏+]

标签:rup   dev   mwl   bin   cpm   tee   mha   api   wpc   

在实际的脚本开发中,我们需要用到python 的异常处理来捕捉异常和抛异常,所以我们有需要学习和使用python 的异常处理。

代码示例:

>>> open(‘abc.txt‘,‘r‘)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
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... 来接收这个错误。打开文件写入:
try:
open("abc.txt",‘r‘)
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", line 3, in <module>
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...

 我们不管线捕捉到的是什么错误,无论错误是不是发生,这些代码“必须”运行,比如文件关闭,释放锁,把数据库连接返还给连接池等。
创建文件poem.txt
技术分享

tryf.py

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", line 18, in <module>
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 异常断言

标签:rup   dev   mwl   bin   cpm   tee   mha   api   wpc   

原文地址:http://www.cnblogs.com/jshtest/p/6364917.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!