Python 学习入门(19)—— 异常

来源:互联网 发布:我的世界如何查看端口 编辑:程序博客网 时间:2024/06/12 18:21

在项目开发中,异常处理是不可或缺的。异常处理帮助人们debug,通过更加丰富的信息,让人们更容易找到bug的所在。异常处理还可以提高程序的容错性

我们之前在讲循环对象的时候,曾提到一个StopIteration的异常,该异常是在循环对象穷尽所有元素时的报错。

我们以它为例,来说明基本的异常处理。

一个包含异常的程序:

re = iter(range(5))for i in range(100):    print re.next()print 'HaHaHaHa'

首先,我们定义了一个循环对象re,该循环对象将进行5次循环,每次使用序列的一个元素。

在随后的for循环中,我们手工调用next()函数。当循环进行到第6次的时候,re.next()不会再返回元素,而是抛出(raise)StopIteration的异常。整个程序将会中断

 

我们可以修改以上异常程序,直到完美的没有bug。但另一方面,如果我们在写程序的时候,知道这里可能犯错以及可能的犯错类型,我们可以针对该异常类型定义好”应急预案“。

re = iter(range(5))
try:    for i in range(100):        print re.next()except StopIteration:    print 'here is end ',iprint 'HaHaHaHa'

在try程序段中,我们放入容易犯错的部分。我们可以跟上except,来说明如果在try部分的语句发生StopIteration时,程序该做的事情。如果没有发生异常,则except部分被跳过。

随后,程序将继续运行,而不是彻底中断。

 

完整的语法结构如下:

try:
    ...except exception1:    ...except exception2:
...
except: ...
else: ...finally: ...

 

如果try中有异常发生时,将执行异常的归属,执行except。异常层层比较,看是否是exception1, exception2...,直到找到其归属,执行相应的except中的语句。如果except后面没有任何参数,那么表示所有的exception都交给这段程序处理。比如:

try:    print(a*2)except TypeError:    print("TypeError")except:    print("Not Type Error & Error noted")

由于a没有定义,所以是NameError。异常最终被except:部分的程序捕捉。

 

如果无法将异常交给合适的对象,异常将继续向上层抛出,直到被捕捉或者造成主程序报错。比如下面的程序

def test_func():
    try:        m = 1/0    except NameError:        print("Catch NameError in the sub-function")try:    test_func()except ZeroDivisionError:    print("Catch error in the main program")

子程序的try...except...结构无法处理相应的除以0的错误,所以错误被抛给上层的主程序。

 

如果try中没有异常,那么except部分将跳过,执行else中的语句。

finally是无论是否有异常,最后都要做的一些事情。

流程如下,

try->异常->except->finally

try->无异常->else->finally

 

我们也可以自己写一个抛出异常的例子:

print 'Lalala'raise StopIterationprint 'Hahaha'

(注意,这个例子不具备任何实际意义。读者可探索更多有意义的例子。)

StopIteration是一个类。当我们raise它的时候,有一个中间环节,就是Python利用StopIteration生成一个该类的一个对象。Python实际上举出的,是这一个对象。当然,也可以直接写成:

raise StopIteration()


示例:

[python] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. #!/usr/bin/env python  
  2. # -*- coding: utf-8 -*-  
  3.   
  4. ''''' 
  5. @author: homer 
  6. @see: ithomer.net 
  7. '''  
  8.   
  9. # 普通异常  
  10. def test_1():  
  11.     try:  
  12.         file("hello.txt""r")  
  13.         print("read file...")  
  14.     except IOError:  
  15.         print("no file")        # no file  
  16.     except:  
  17.         print("except error")  
  18.   
  19. # 嵌套异常  
  20. def test_2():  
  21.     try:  
  22.         s = "hello"  
  23.         try:  
  24.             print s[0] + s[1]   # he  
  25.             print s[0] - s[1]   # error  
  26.         except TypeError:  
  27.             print("str not support subtraction operator")       # str not support subtraction operator  
  28.     except:  
  29.         print("except error")  
  30.   
  31. # finally子句都会被执行  
  32. def test_3():  
  33.     try:  
  34.         f = open("hello.txt""r")  
  35.         try:  
  36.             print(f.read(6))            # hello.  of hello.txt  
  37.         except:  
  38.             print("read file except")  
  39.         finally:  
  40.             print("release resource")  
  41.             f.close()  
  42.     except IOError:  
  43.         print("file not exist")         # file not exist  
  44.           
  45. # raise显示地引发异常,raise后面的语句将不能执行  
  46. def test_4():  
  47.     try:  
  48.         s = None  
  49.         if s is None:  
  50.             print("s is none")  
  51.             raise NameError         # 如果引发NameError异常,后面的代码将不能执行  
  52.         print(len(s))  
  53.     except TypeError:  
  54.         print("None is no lenght")  
  55.   
  56. # 自定义异常  
  57. class CustomException(Exception):  
  58.     def __init__(self, x, y):  
  59.         Exception.__init__(self, x, y)  
  60.         self.x = x  
  61.         self.y = y  
  62.           
  63. def test_5():  
  64.     try:  
  65.         x = 3  
  66.         y = 2  
  67.         if x % y > 0:  
  68.             print x/y       # 1  
  69.             raise CustomException(x, y)                             # 显示指定异常  
  70.     except CustomException, div:  
  71.         print("CustomException: x/y = %.2f" % (div.x/div.y))        # CustomException: x/y = 1.00  
  72.   
  73.   
  74. if __name__ == "__main__":  
  75.     test_1()  
  76.     test_2()  
  77.     test_3()  
  78.     test_4()  
  79.     test_5()  

总结:

try: ... except exception: ... else: ... finally: ...
raise exception

0 0
原创粉丝点击