首先放出python异常树镇楼
python使用try except finally 处理异常 使用raise关键字抛出异常,在学习异常的时候对异常的理解出现了小小的问题,下面将详细介绍一下
现在这么一个简单例子
def foo(s):
n=int(s)
if n==0 :
raise ValueError('invalid value:%s'%s)
return 10/n
def bar():
try:
foo('0')
except ValueError as e:
print('ValueError!')
bar()
结果就是打印除ValueError! 这个地方的理解就是,在foo函数中抛出异常,然后bar中捕获异常,输出ValueError! 出现异常后后面的内容将不会执行。如果要执行可以使用logging模块记录错误内容 比如下面的例子
import logging
def foo(s):
return 10/int(s)
def bar(s):
return foo(s)*2
def main():
try:
bar('0')
print('hello')
except Exception as e:
logging.exception(e)
main()
print('END')
将打印错误信息后进行打印END
好回到上面,在前面那个例子中,捕获异常后还可以抛出异常
def foo(s):
n=int(s)
if n==0 :
raise ValueError('invalid value:%s'%s)
return 10/n
def bar():
try:
foo('0')
except ValueError as e:
print('ValueError!')
raise
bar()
这样,在捕获异常后又将异常抛出,这仅是为了记录异常信息,然后将异常交给上层调用者处理,显然上面在输出ValueError后仍然会输出异常信息。
值得说明的是,主动抛出异常的格式为 raise 异常名称(‘异常描述’) ,也就是说,抛出的异常会携带这异常描述,这也就是为什么在捕获异常后又抛出该异常后仍然会输出异常描述的原因。
最后能,在自定义异常类中,要注意开头给的异常树中的关系合理继承。
然后最后放一个自定义异常的简单模板
class MyError(Exception):
def __init__(self,ErrorInfo):
super().__init__(self) #初始化父类
self.errorinfo=ErrorInfo
def __str__(self):
return self.errorinfo
if __name__ == '__main__':
try:
raise MyError('error!')
except MyError as e:
print(e)