Python中的异常、分类及处理、手动引发异常及自定义异常


异常

  • 广义上的错误分为错误和异常
  • 错误值得是可以人为避免的
  • 异常指得是在语法逻辑正常的前提下,运行时出现的问题
  • 在python中异常是一个类,可以处理和使用

异常的分类

BaseException		所有异常的基类
SystemExit			解释器请求退出
KeyboardInterrupt	用户中断执行(通常是输入^C)
Exception			常规错误的基类
StopIteration 		迭代器没有更多的值
GeneratorExit 		生成器(generator)发生异常来通知退出
StandardError		所有的内建标准异常的基类
ArithmeticError 	所有数值计算错误的基类
FloatingPointError 	浮点计算错误
OverflowError		数值运算超出最大限制
ZeroDivisionError	除(或取模)零 (所有数据类型)
AssertionError		断言语句失败
AttributeError		对象没有这个属性
EOFError 			没有内建输入,到达EOF 标记
EnvironmentErro		操作系统错误的基类
IOError 			输入/输出操作失败
OSError 			操作系统错误
WindowsError		系统调用失败
ImportError 		导入模块/对象失败
LookupError 		无效数据查询的基类
IndexError			序列中没有此索引(index)
KeyError			映射中没有这个键
MemoryError			内存溢出错误(对于Python 解释器不是致命的)
NameError			未声明/初始化对象 (没有属性)
UnboundLocalError 	访问未初始化的本地变量
ReferenceError		弱引用(Weak reference)试图访问已经垃圾回收了的对象
RuntimeError 		一般的运行时错误
NotImplementedError	尚未实现的方法
SyntaxError			Python 语法错误
IndentationError	缩进错误
TabError			Tab 和空格混用
SystemError 		一般的解释器系统错误
TypeError			对类型无效的操作
ValueError 			传入无效的参数
UnicodeError 		Unicode 相关的错误
UnicodeDecodeError 	Unicode 解码时的错误
UnicodeEncodeError 	Unicode 编码时错误
UnicodeTranslateError	Unicode 转换时错误
Warning 			警告的基类
DeprecationWarning	关于被弃用的特征的警告
FutureWarning 		关于构造将来语义会有改变的警告
OverflowWarning		旧的关于自动提升为长整型(long)的警告
PendingDeprecationWarning	关于特性将会被废弃的警告
RuntimeWarning 		可疑的运行时行为(runtime behavior)的警告
SyntaxWarning		可疑的语法的警告
UserWarning			用户代码生成的警告

异常处理

  • 不能保准程序永远执行

  • 但是,必须保证程序在最坏的情况下的问题被妥善处理

  • python的异常处理模块全部语法为:

      try:
          尝试实现某一个操作
          如果没处理异常,任务就可以完成
          如果出现异常,将一场从当前代码块扔出去尝试解决异常
      except 异常类型1:
          解决方案:用于尝试在此处解决类型1异常问题
      except 异常类型2:
          解决方案:用于尝试在此处解决类型2异常问题
      except (异常类型1, 异常类型2.......):
          解决方案:针对多个异常使用相同的方法处理异常
      except :
          解决方案:所有异常的解决方案
      else:
          如果没有出现异常将会执行此处代码
      finally:
          管你有没有异常,都要执行的代码
    
  • 流程

    • 执行try下面的语句
    • 如果出现异常,则在except语句例查找对应异常并进行处理
    • 如果没有出现异常,则要执行else里面的语句
    • 最后,不管是否出现异常,都要执行finally里面的语句
  • 除except(最少一个)意外,else和finally可选

try:
    num = int(input("Plz input your number:"))
    rst = 100 / num
    print("计算结果是:{0}".format(rst))
    # 捕获异常后,实例化,出错信息会在实例中
    # 需要把越具体的错误越往前方
    # 在处理异常时,一旦遇到一个异常,则不会继续往下查看,直接进行下一个
except ZeroDivisionError as e:
    print("这是个啥玩意")
    print(e)
    # exit() 是退出程序的意思
    exit()
except NameError as e:
    print("名字起错了")
    print(e)
    exit()
except AttributerError as e:
    print("属性错了")
    print(e)
    exit()
    # 所有异常都继承自Exception
    # 如果下面这个话,所有异常都会被拦截
except Exception as e:
    print("我也不知道出什么错了")
    print(e)
    exit()
print("hehehehheheh")

手动引发异常

  • 当某些情况出现时,用户希望自己引发一个异常,可以使用
  • raise 关键字来引发异常
try:
    print(3.2425926)
    raise NameError
    print("还有呢")
except NameError:
    print('An exception flew by!')
except ValueError as e:
    print("知错了")
finally:
    print("我肯定会被执行的")

>>>
3.2425926
An exception flew by!
我肯定会被执行的

自定义异常

  • 只要是raise异常,推荐自定义异常
  • 在自定义异常时,一般包含以下内容
    • 自定义发生异常的异常代码
    • 自定义发生异常后的问题提示
    • 自定义发生异常的行数
  • 最终的目的是,一旦发生异常,方便程序员快速定位异常位置
class DanaError(ValueError):
    pass
    
try:
    print(3.2425926)
    raise DanaError
    print("还有呢")
except NameError:
    print('An exception flew by!')
except DanaError: # 自定义异常 如果没有这个,会报ValueError,因为继承自ValueError
    print("DanaError")
except ValueError as e:
    print("知错了")
finally:
    print("我肯定会被执行的")

>>>
3.2425926
DanaError
我肯定会被执行的
try :
    num = int(input("plz input your number"))
    rst = 100/num
    print("计算结果是:{0}".format(rst))
except Exception as e:
    print("Exception")
else: # 没有异常时会执行下面语句
    print("No Exception")
finally: # 不管有没有都执行
    print("反正我会被执行")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值