作为程序员,在不退休或转型之前,我们就会不停的写代码。而代码总是伴随着各种错误,异常(hello world这种除外- -)。
所以了解异常,学会异常的处理就很重要了,也是必修课。
先了解一个小知识:
Exception:可以认为是python中所以异常的父,也是所有异常的基类。其实在Exception之上还有一个baseException,不过当我们重写或自定义异常时都是继承Exception,所以一般管Exception为异常的基类
处理异常
最简单的实例:
try:
1/0
except Exception as e:
print(e) # 打印出division by zero,程序继续执行
print("continue run...") # continue run...
在except语句块中,我们可以进行对异常的处理,一般是先记录在log中再进行其他操作。
(推荐一个python内置模块。traceback,它可以输出更加详细的错误信息,并且还支持格式化,写入文件等操作,感兴趣的同学可以自行查找资料哈,这里只给大家简单演示下)
import traceback
def demo():
try:
1 / 0
except Exception as e:
traceback.print_exc() # 不会中断程序
print("continue run...") # continue run...
抛出异常:
try:
1/0
except Exception as e:
raise e # 程序在此中断,抛出异常
print("continue run...") # continue run...
注意:如果只是对异常进行捕获、记录时,程序不会中断,会继续执行。如果要在抛出异常时中断程序,可以使用raise,或者记录异常后,return。
finally:
会强制让程序执行该语句块里的代码。(遇到raise,return程序都不会停止)
def demo():
try:
1 / 0
except Exception as e:
raise e # 因为有finally在,所以会继续执行完finally里的代码
finally:
print("continue run...") # continue run...
print("finally others") # 注意!!这句并不会执行到
自定义异常
在实际开发中,python内置的异常可能满足不了我们的需求,这个时候我们就需要自行定义异常类型
定义异常类型一定要继承Exception,并且只能用raise抛出
示例:
class Demo_exception(Exception):
def __init__(self, len):
self.len = len
def __str__(self):
return "{} is beyond range of 4".format(self.len)
def demo():
len = 5
try:
if len > 4:
raise Demo_exception(len) # 模拟在可能异常的地方进行抛出
else:
print(len)
except Demo_exception as result: # 这里只有在上面raise Demo_exception这个自定义异常后才会生效
print('异常信息为:{}'.format(result))
注意:当我们自定义了异常后,一定要确认这个异常处理类能够捕获到对应的错误,否则建议直接使用Exception。
如果定义了而捕获不到,则会造成程序的中断,不会达到我们预期的效果。
多个异常的情况
示例
def demo():
try:
1/0 # 此处会抛出 ZeroDivisionError
except KeyError as e: # 没有捕获到,进入下一个except语句块继续捕获
print("KeyError run...")
raise e
except ZeroDivisionError as e: # 成功捕获到
print("ZeroDivisionError run...") # ZeroDivisionError run...
raise e
如果第一个except语句块就已经捕获到了异常,则不会向下继承进行捕获。也就是说,我们可以用多个异常类型进行捕获,但很不推荐。这样造成不必要的资源浪费(python是解释型语言,,本身就比其他语言要慢。。多执行一步,在项目较小或者流量少的时候不明显,不管怎么说,用户体验第一!)。
如果本篇文章对你有帮助,可否在文章右侧点个赞再走呢~~
本文为原创,转载请注明出处