python中的异常处理
与其他语言一致,python也有自己的异常处理逻辑;
try:
li = [11,22] # 一个列表中存在2个内容
li[33] # 索引第33个值 因为不存在而报错
except Exception as e:
print(e) # list index out of range
这时最简单的异常处理逻辑:
其中Exception
为全部错误类型:所有的报错都可以通过他处理;
当然也可以对其进行拆分,如下:
try:
li = [11,22]
li[33]
except IndexError as e:
print('IndexError:',e) # IndexError: list index out of range
except ValueError as e:
print('ValueError:',e)
except Exception as e:
print(e)
细分处理后,在满足上面任一一个细分错误后,将不再执行其他包括最后的总错误逻辑。
常用的细分错误大致包含:
AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x
IOError 输入/输出异常;基本上是无法打开文件
ImportError 无法引入模块或包;基本上是路径问题或名称错误
IndentationError 语法错误(的子类) ;代码没有正确对齐
IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]
KeyError 试图访问字典里不存在的键
KeyboardInterrupt Ctrl+C被按下
NameError 使用一个还未被赋予对象的变量
SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了)
TypeError 传入对象类型与要求的不符合
UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,
导致你以为正在访问它
ValueError 传入一个调用者不期望的值,即使值的类型是正确的
异常处理还包含else
与finally
else
当不出差时,会执行else
中的代码;
finally
无论出不出错,最后都会执行。
try:
li = [11,22]
li[33]
except IndexError as e:
print('IndexError:',e) # IndexError: list index out of range
except ValueError as e:
print('ValueError:',e) # 上面已经对出错处理,下面不在处理
except Exception as e:
print(e) # 上面已经对出错处理,下面不在处理
else:
print('else') # 因为有出错 没有执行
finally:
print('finally') # finally
除了上述的异常处理,python还存在主动抛出异常处理逻辑:
try:
li = [11,22]
li[1]
raise Exception('日子没法过了。。。')
except Exception as e:
print(e) # 日子没法过了。。。
此做法常用于代码没有错误,但是返回没有满足预期的情况下,直接将其进行错误处理,并将其直接记录到在作错误记录日志的逻辑中。
对于异常处理,还包括自定义异常处理:
对于自定义异常处理,只需要建立一个继承自Exception
的类即可:
class customError(Exception):
def __init__(self,msg):
self.message = msg
def __str__(self):
return self.message
try:
raise customError('我错了。。。')
except customError as e: # 定义的e对象通过__str__()方法,获取返回
print('customError',e) # customError 我错了。。。
最后一个异常处理方法叫做:assert
断言,类似于pycharm中的打断点:
在满足assert
后跟的条件时,程序正常进行,assert当成不存在,否则直接报错;
用于强制用户服从,不服从直接报错,可以使用try捕获,但一般不捕获;
a = 2
print(a) # 2
assert a<5 # 满足条件 断延等同不存在
print('yes') # yes
assert a>5 # 不满足条件 断延直接报错
print('yes') # 没有执行