✅作者简介:人工智能专业本科在读,喜欢计算机与编程,写博客记录自己的学习历程。
🍎个人主页: 小嗷犬的博客
🍊个人信条:为天地立心,为生民立命,为往圣继绝学,为万世开太平。
🥭本文内容:Python 异常处理机制
@TOC
1.try-except 语句
Python解释器在运行出现异常时,会返回异常信息,告诉我们错误出现在哪一行,错误类型是什么,具体原因是什么。在异常可能发生的地方添加异常处理程序,对于用户明确错误是一种好方法。
Python使用
try-except
语句实现异常处理,基本的语法格式如下:
try:
<<<语句块1>>>
except <<<异常类型>>>:
<<<发生异常执行的语句>>>
else:
<<<没有发生异常执行的语句>>>
finally:
<<<不管有没有异常都要执行的语句块>>>
# 分别输入 No 和 5 试试看:
try:
alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
idx = int(input("请输入一个整数: "))
print(alphabet[idx])
except ValueError:
print("输入错误,请输入一个整数!")
else:
print("没有发生异常")
finally:
print("程序执行完毕,不知道是否发生了异常")
try-except
语句中可以存在多个except
分支,用于捕获不同的错误类型。
一个except
分支也可以捕获多种类型的错误,不同错误类型之间用逗号隔开。
2.异常类型
Python异常信息中最重要的部分是异常类型,它表明了发生异常的原因,也是程序处理异常的依据。下表列出了Python中的标准异常类型:
异常名称 | 描述 |
---|---|
BaseException | 所有异常的基类 |
SystemExit | 解释器请求退出 |
KeyboardInterrupt | 用户中断执行(通常是输入^C) |
Exception | 常规错误的基类 |
StopIteration | 迭代器没有更多的值 |
GeneratorExit | 生成器(generator)发生异常来通知退出 |
StandardError | 所有的内建标准异常的基类 |
ArithmeticError | 所有数值计算错误的基类 |
FloatingPointError | 浮点计算错误 |
OverflowError | 数值运算超出最大限制 |
ZeroDivisionError | 除(或取模)零 (所有数据类型) |
AssertionError | 断言语句失败 |
AttributeError | 对象没有这个属性 |
EOFError | 没有内建输入,到达EOF 标记 |
EnvironmentError | 操作系统错误的基类 |
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 | 用户代码生成的警告 |
3.raise 抛出异常
raise
的语法格式如下:
raise [Exception [, args [, traceback]]]
语句中Exception
是异常的类型(例如:NameError
)参数标准异常中任一种,args
是自已提供的异常参数。最后一个参数是可选的(在实践中很少使用),如果存在,是跟踪异常对象。
代码实例:
def judgeLevel(level):
if level < 1:
raise Exception("Invalid level!", level)
level = 0
judgeLevel(level)
# 触发异常后,后面的代码就不会再执行
print(f'当前层数为:{level}')
4.自定义异常
通过创建一个新的异常类,程序可以命名它们自己的异常。自定义异常直接或间接地继承自Exception
类。以下为与
RuntimeError
相关的实例,实例中创建了一个类,基类为RuntimeError
,用于在异常触发时输出更多的信息。
class Networkerror(RuntimeError):
def __init__(self, arg):
self.args = arg
在你定义以上类后,你可以用
raise
抛出该异常,如下所示:
class Networkerror(RuntimeError):
def __init__(self, arg):
self.args = arg
try:
raise Networkerror("Bad hostname")
except Networkerror,e:
print e.args