一、异常的传递

1. try嵌套中

  1. import time 

  2. try: 

  3.    f = open('test.txt') 

  4.     try: 

  5.         while True: 

  6.             content = f.readline() 

  7.             if len(content) == 0: 

  8.                 break 

  9.             time.sleep(2) 

  10.     finally: 

  11.        f.close() 

  12.         print('关闭文件') 

  13. except : 

  14.    print("没有这个文件") 

  15. finally: 

  16.     print("最后的finally") 

  17. # 这是test.txt文件中读取到信息 

运行结果:

2. 函数嵌套调用中

  1. def test1(): 

  2.      print("----test1-1----") 

  3.      print(num) 

  4.      print("----test1-2----") 

  5.  def test2(): 

  6.      print("----test2-1----") 

  7.      test1() 

  8.      print("----test2-2----") 

  9.  def test3(): 

  10.      try: 

  11.          print("----test3-1----") 

  12.          test1() 

  13.          print("----test3-2----") 

  14.      except Exception as result: 

  15.          print("捕获到了异常,信息是:%s"%result) 

  16.      print("----test3-2----") 

  17.  test3() 

  18.  print("------华丽的分割线-----") 

  19.  test2() 

运行结果:

小总结:

如果try嵌套,那么如果里面的try没有捕获到这个异常,那么外面的try会接收到这个异常,然后进行处理,如果外边的try依然没有捕获到,那么再进行传递。

如果一个异常是在一个函数中产生的,例如函数A---->函数B---->函数C,而异常是在函数C中产生的,那么如果函数C中没有对这个异常进行处理,那么这个异常会传递到函数B中,如果函数B有异常处理那么就会按照函数B的处理方式进行执行;如果函数B也没有异常处理,那么这个异常会继续传递,以此类推。。。如果所有的函数都没有处理,那么此时就会进行异常的默认处理。

二、抛出自定义的异常

你可以用raise语句来引发一个异常。异常/错误对象必须有一个名字,且它们应是Error或Exception类的子类

下面是一个引发异常的例子:

  1. class ShortInputException(Exception): 

  2.     '''自定义的异常类''' 

  3.     def __init__(self, length, atleast): 

  4.         #super().__init__() 

  5.         self.length = length 

  6.         self.atleast = atleast 

  7. def main(): 

  8.     try: 

  9.         s = input('请输入 --> ') 

  10.         if len(s) < 3: 

  11.             # raise引发一个你定义的异常 

  12.             raise ShortInputException(len(s), 3) #自定义异常长度为3。 

  13.     except ShortInputException as result:#x这个变量被绑定到了错误的实例 

  14.         print('ShortInputException: 输入的长度是 %d,长度至少应是 %d'% (result.length, result.atleast)) 

  15.     else: 

  16.         print('没有异常发生.') 

  17. main() 

运行结果:

以上程序中,关于#super().init()代码的说明:

这一行代码,可以调用也可以不调用,建议调用。

因为__init__方法往往是用来对创建完的对象进行初始化工作,如果在子类中重写了父类的__init__方法,即意味着父类中的很多初始化工作没有做,这样就不保证程序的稳定了,所以在以后的开发中,如果重写了父类的__init__方法,最好是先调用父类的这个方法,然后再添加自己的功能。

三、异常处理中抛出异常

  1. class Test(object): 

  2.     def __init__(self, switch): 

  3.         self.switch = switch #开关 

  4.     def calc(self, a, b): 

  5.         try: 

  6.             return a/b 

  7.         except Exception as result: 

  8.             if self.switch: 

  9.                 print("捕获开启,已经捕获到了异常,信息如下:") 

  10.                 print(result) 

  11.             else: 

  12.                 #重新抛出这个异常,此时就不会被这个异常处理给捕获到,从而触发默认的异常处理 

  13.                 raise 

  14. a = Test(True) 

  15. a.calc(11,0) 

  16. print("----------------------华丽的分割线----------------") 

  17. a.switch = False 

  18. a.calc(11,0) 

运行结果:

四、总结

本文基于Python基础,详细的讲解了运行过程中遇到各种异常,应该采取什么样的处理方式,对各种异常提供有效的解决方案。通过一个个小项目实际操作,运行结果展示,能够更好的解决问题。希望可以帮助你更好的学习Python


点赞(0)

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部