注:最后有面试挑战,看看自己掌握了吗
文章目录
- 错误分类
- 捕捉异常实例
- 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




















