当前位置:   article > 正文

【Python】异常捕捉,异常传递,raise主动抛出异常,及自定义异常_python raise函数间传递异常

python raise函数间传递异常

异常捕捉

        简单的异常捕捉语法

        在程序开发中,如果 对某些代码的执行不能确定是否正确,可以增加 try(尝试) 来 捕获异常,防止程序直接中断

  1. try:
  2. 尝试执行的代码
  3. except:
  4. 出现错误的处理

        错误类型介绍

                下面我给一个Python的常见异常错误类型表,供大家参考

         错误类型捕捉完整代码

在程序执行时,可能会遇到 不同类型的异常,并且需要 针对不同类型的异常,做出不同的响应,这个时候,就需要捕获错误类型了。

  1. try:
  2. # 尝试执行的代码
  3. pass
  4. except 错误类型1:
  5. # 针对错误类型1,对应的代码处理
  6. pass
  7. except 错误类型2:
  8. # 针对错误类型2,对应的代码处理
  9. pass
  10. except (错误类型3, 错误类型4):
  11. # 针对错误类型3 和 4,对应的代码处理
  12. pass
  13. except Exception as result:
  14. # 打印错误信息
  15. print(result)
  16. else:
  17. # 没有异常才会执行的代码
  18. pass
  19. finally:
  20. # 无论是否有异常,都会执行的代码
  21. print("无论是否有异常,都会执行的代码")

具体例子:

  1. try:
  2. num = int(input("请输入整数:"))
  3. result = 8 / num
  4. print(result)
  5. except ValueError:
  6. print("请输入正确的整数")
  7. except ZeroDivisionError:
  8. print("除 0 错误")
  9. except Exception as result:
  10. print("未知错误 %s" % result)
  11. else:
  12. print("正常执行")
  13. finally:
  14. print("执行完成,但是不保证正确")

当不确定错误类型的,可以统一用Exception去捕捉异常,但是为了错误类型更加清晰不建议这样处理,而且SystemExit等几种异常不继承于Exception,Exception无法捕捉SystemExit抛出的异常

  1. try:
  2. exit(100)
  3. except Exception as result:
  4. print("退出错误 %s" % result) #无法捕捉
  5. #except SystemExit as result:
  6. #print("退出错误 %s" % result) #可捕捉
  7. print("当捕获到异常时,程序不退出,程序还执行到这一步")

异常传递

  • 异常的传递 —— 当 函数/方法 执行 出现异常,会 将异常传递 给 函数/方法 的 调用一方
  • 如果 传递到主程序,仍然 没有异常处理,程序才会被终止

    提示: 

  • 在开发中,可以在主函数中增加 异常捕获
  • 而在主函数中调用的其他函数,只要出现异常,都会传递到主函数的 异常捕获 中
  • 这样就不需要在代码中,增加大量的 异常捕获,能够保证代码的整洁
    1. class MufCalc(object):
    2. m = False
    3. def calc(self,exp):
    4. try:
    5. return eval(exp)
    6. except ZeroDivisionError:
    7. if self.m:
    8. print("cool")
    9. else:
    10. raise
    11. app = MufCalc()
    12. app.calc(2/0)

    运行结果:

    1. Traceback (most recent call last):
    2. File "D:/code/utils/test.py", line 25, in <module>
    3. app.calc(2/0)
    4. ZeroDivisionError: division by zero

    raise主动抛出异常

在开发中,除了 代码执行出错 Python 解释器会 抛出 异常之外,还可以根据 应用程序 特有的业务需求 主动抛出异常。通常我们通过try except捕获的异常叫做被动捕获,它其实是需要程序员进行处理的,比如对错误的变量内容做一些改正让其继续执行。但是主动抛出异常通常不需要再进行处理,程序员已经确定这个地方必须抛出异常给用户,并且中断程序执行,基于这种情况下程序员就不用再对异常进行处理了

  • Python 中提供了一个通用 Exception 异常类
  • 在开发时,如果满足 特定业务需求时,希望 抛出异常,可以:
    1. 创建 一个 Exception 的 对象
    2. 使用 raise 关键字 抛出 异常对象
  1. raise Exception("This input type is invaild.")
  2. raise RuntimeError('testError')
  3. raise ValueError("输入值错误")

自定义异常

通过自定义异常,我们可以不用拘泥于Python自带的异常错误类型,定义更多自己想要的错误类型,精确的控制出错的时机和处理方式。自定义异常一般继承Exception或者BaseException

  1. class ShortInputException(Exception):
  2. def __init__(self, length, least_length):
  3. super().__init__()
  4. self.length = length
  5. self.least_length = least_length
  6. def __str__(self):
  7. return '您输入的长度为:{},最短长度为:{}'.format(self.length, self.least_length)
  8. try:
  9. content = input('请输入内容:')
  10. if len(content) < 5:
  11. raise ShortInputException(len(content), 5)
  12. else:
  13. print('符合要求')
  14. except ShortInputException as e:
  15. print(e)
  16. '''
  17. 请输入内容:ASD
  18. 您输入的长度为:3,最短长度为:5

参考文章:

python使用raise抛出自定义异常_CSDN-CSDN博客_python raise抛出异常

【Python】raise主动抛出异常,自定义异常_mjiansun的专栏-CSDN博客_python 主动抛出异常

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/205144
推荐阅读
相关标签
  

闽ICP备14008679号