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

异常捕捉

        简单的异常捕捉语法

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


try:
    尝试执行的代码
except:
    出现错误的处理

        错误类型介绍

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

         错误类型捕捉完整代码

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


try:
    # 尝试执行的代码
    pass
except 错误类型1:
    # 针对错误类型1,对应的代码处理
    pass
except 错误类型2:
    # 针对错误类型2,对应的代码处理
    pass
except (错误类型3, 错误类型4):
    # 针对错误类型3 和 4,对应的代码处理
    pass
except Exception as result:
    # 打印错误信息
    print(result)
else:
    # 没有异常才会执行的代码
    pass
finally:
    # 无论是否有异常,都会执行的代码
    print("无论是否有异常,都会执行的代码")

具体例子:

try:
    num = int(input("请输入整数:"))
    result = 8 / num
    print(result)
except ValueError:
    print("请输入正确的整数")
except ZeroDivisionError:
    print("除 0 错误")
except Exception as result:
    print("未知错误 %s" % result)
else:
    print("正常执行")
finally:
    print("执行完成,但是不保证正确")

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

try:
    exit(100)
except Exception as result:
    print("退出错误 %s" % result) #无法捕捉
#except SystemExit as result:
    #print("退出错误 %s" % result) #可捕捉

print("当捕获到异常时,程序不退出,程序还执行到这一步")

异常传递

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

    提示: 

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

    运行结果:

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

    raise主动抛出异常

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

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

自定义异常

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

class ShortInputException(Exception):
 
    def __init__(self, length, least_length):
        super().__init__()
        self.length = length
        self.least_length = least_length
 
    def __str__(self):
        return '您输入的长度为:{},最短长度为:{}'.format(self.length, self.least_length)
 
 
try:
    content = input('请输入内容:')
    if len(content) < 5:
        raise ShortInputException(len(content), 5)
    else:
        print('符合要求')
except ShortInputException as e:
    print(e)
'''
请输入内容:ASD
您输入的长度为:3,最短长度为:5

参考文章:

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

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

你可能感兴趣的:(python,开发语言)