注:最后有面试挑战,看看自己掌握了吗
文章目录
- 错误分类
- 捕捉异常实例
- finally的使用
- 捕捉特定异常
- 抛出异常
- 用户自定义异常
🌸I could be bounded in a nutshell and count myself a king of infinite space.
特别鸣谢:木芯工作室 、Ivan from Russia
错误分类
低级错误:代码错误
中级错误:边界值没考虑,传入数据没考虑类型
高级错误:程序运行过程中的不确定性环境因素
捕捉异常实例
def print_D(dic):
i=0
try:
len1=len(dic)
while i<len1:
print(dic.popitem())
i+=1
except:
print("请传递字典!")
if '__main__' == __name__:
print_D({1:100,2:"zzz"})
print_D(1)
finally的使用
强制性,比sys.exit()
级别高
def print_D(dic):
i=0
try:
len1=len(dic)
while i<len1:
print(dic.popitem())
i+=1
except:
print("请传递字典!")
finally:
print("zuihou")
if '__main__' == __name__:
print_D(1)
捕捉特定异常
使用特定异常判断程序出错在实际项目很少使用–不如直接编写代码的时候避免
def print_D(dic):
i=0
try:
t+=1
except(NameError):
print("没定义呢!")
finally:
print("zuihou")
if '__main__' == __name__:
print_D({1:12})
抛出异常
抛出以后要有处理的函数
raise Exception
def mye( level ):
if level < 1:
raise Exception("Invalid level!")
# 触发异常后,后面的代码就不会再执行
try:
mye(0) # 触发异常
except(Exception):
print(123)
else:
print(456)
用户自定义异常
通过创建一个新的异常类,程序可以命名它们自己的异常。异常应该是典型的继承自Exception
类,通过直接或间接的方式。
以下为与RuntimeError
相关的实例,实例中创建了一个类,基类为RuntimeError
,用于在异常触发时输出更多的信息。
在try语句块中,用户自定义的异常后执行except块语句,变量 e 是用于创建Networkerror类的实例。
class Networkerror(RuntimeError):
def __init__(self, arg):
self.args = arg
在你定义以上类后,你可以触发该异常,如下所示:
try:
raise Networkerror("Bad hostname")
except Networkerror,e:
print e.args