Python中的异常处理
1.异常类型
异常名称
描述
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
用户代码生成的警告
2.异常处理
1)try/except语句
捕捉异常通常用try(捕捉错误)/except(处理错误)语句。如果你不想在异常发生时结束你的程序,只需在try里捕获它。异常可带参数,用于说明异常原因
try:
fh = open("testfile", "w")
fh.write("这是一个测试文件,用于测试异常!!")
except (IOError,RuntimeError): # 当出现这两种error中的一种时,执行except后面的操作
print("Error: 没有找到文件或读取文件失败")
except Exception as e: # 使用异常基类捕获
print("Error: 出错")
else:
print("内容写入文件成功")
fh.close()
2)try/finally语句
try-finally 语句无论是否发生异常都将执行最后的代码。
try:
fh = open("testfile", "w")
fh.write("这是一个测试文件,用于测试异常!!")
finally:
print("Error: 没有找到文件或读取文件失败")
3.自己设置异常(用于bug修改、错误检查)
我们可以使用raise语句自己触发异常
raise语法格式如下:
raise [Exception [, args [, traceback]]]
语句中Exception是异常的类型(例如,NameError)参数是一个异常参数值。该参数是可选的,如果不提供,异常的参数是"None"。
最后一个参数是可选的(在实践中很少使用),如果存在,是跟踪异常对象。例子如下:
def functionName( level ):
if level < 1:
raise Exception("Invalid level!", level)
# 触发异常后,后面的代码就不会再执行
对于自定义的异常,在使用except语句处理异常时,一定要将Exception中的异常名作为except语句的一个参数。例子如下:
try:
#正常逻辑
except "Invalid level!":
#触发自定义异常
else:
#其余代码
4.自己创建异常类型,用于常见异常复用
一个异常可以是一个字符串,类或对象。
class Networkerror(RuntimeError): # 基于RuntimeError类创建一个新的类
def __init__(self, arg): # 定义一个函数
self.args = arg
try:
raise Networkerror("Bad hostname") #抛出一个Networkerror异常
except Networkerror as e: #匹配异常的类型,当出现了Networkerror型异常时,执行该except语句,并传递变量e,变量 e 是用于创建Networkerror类的实例,这里的e应该就是这个异常对象?
print(e.args)