• 异常处理


    一:异常处理认识:

    # 请使用代码自定义一个异常类,并抛出该异常;
    # 一:先了解什么是异常: 异常是错误发生的信号,一旦程序出错,并且程序没有处理这个错误,就会跑出异常,并且程序的运行随之终止
    
    # Traceback: 异常的追踪信息
    # ValueError:异常的类型
    # 异常的值:告诉你异常到底是什么样具体的类型
    
    # 2.错误类型:
    # 1.语法错误:在程序执行前就要立刻改正过来
    # 2.逻辑错误
    #ValueError:类型错误
    # num=input(">>: ") #输入hello
    # int(num)
    
     # NameError:   变量名错误,变量名没有定义
    # aaa
    
    # IndexError:  #索引错误
    # l=['egon','aa']
    # l[3]
    
    # KeyError: #访问字典没有的Key
    # dic={'name':'egon'}
    # dic['age']
    
    # AttributeError: #访问类里面没有的属性
    # class Foo:pass
    # Foo.x
    
    # ZeroDivisionError: 1/0  #1不能除以0,无法完成计算
    
    #TypeError: #int类型不可迭代,数字不能循环,
    # for i in 3:
    #     pass
    

    二 异常的种类:

    # 在python中不同的异常可以用不同的类型(python中统一了类与类型,类型即类)去标识,一个异常标识一种错误
    # 常见异常
    '''
    AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x
    IOError 输入/输出异常;基本上是无法打开文件
    ImportError 无法引入模块或包;基本上是路径问题或名称错误
    IndentationError 语法错误(的子类) ;代码没有正确对齐
    IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]
    KeyError 试图访问字典里不存在的键
    KeyboardInterrupt Ctrl+C被按下
    NameError 使用一个还未被赋予对象的变量
    SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了)
    TypeError 传入对象类型与要求的不符合
    UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,
    导致你以为正在访问它
    ValueError 传入一个调用者不期望的值,即使值的类型是正确的
    '''
    
    

    三 异常处理:

    强调一: 对于错误发生的条件,如果是可以预知的,从事应该用if判断预防异常
    # AGE = 10
    # age = input('>>:').strip()
    # if age.isdigit():
    #     age = int(age)
    #     if age > AGE:
    #         print('太大了') #这种就是可以去预知的,且还可以去用判断进行预防错误的发生
    
    
    # 强调二: 错误发生的条件如果是不可预知的,此时应该用异常处理机制,try..except
    '''基本语法为
    try:
        被检测的代码块
    except 异常类型:
        try中一旦检测到异常,就执行这个位置的逻辑'''
    
    # try: #代表检测的意思,检测一下代码的执行
    #     f = open('a.txt','r',encoding='utf-8')
    #     print(next(f),end='')
    #     print(next(f),end='')
    #     print(next(f),end='')
    #     print(next(f),end='')
    #     f.close()  #从文件迭代取信息的时候,无法预知错误发生的条件,而且异常是一定会抛出来的,所以就要去处理
    # except  StopIteration:
    #     print('出错啦!')
    
    # except:捕捉,上端代码的执行,捕捉异常,
    # StopIteration:匹配看是符合什么类型的错误
    
    

    # 四 try..except...详细用法

     1.多分支:被监测的代码块跑出的异常有多重可能性,并且我们需要针对每一种异常类型都定制专门的处理逻辑
    
    
    # try:
    #     print('===> 1')
    #     # name
    #     print('===> 2')
    #     # l =[1,2,3]
    #         l[100]
    #     print('===> 3')
    #     d ={}
    #     d['name']
    #     print('===> 4')
    #
    # except NameError as e:
    #     print(e)
    # except IndexError as e:
    #     print(e)
    # except KeyError as e:
    #     print(e)
    
    # 2.万能异常Exception
    # 被监测的代码块抛出的异常有多种可能性,并且我们针对所有异常类型都只有一种处理逻辑,那就使用 万能异常Exception
    # try:
    #     print('===> 1')
    #     # name
    #     print('===> 2')
    #     l =[1,2,3]
    #     l[100]
    #     print('===> 3')
    #     d ={}
    #     d['name']
    #     print('===> 4')
    #
    # except Exception as e:
    #     print('异常发生啦',e)
    #
    # # 3.异常的其他机构
    # try:
    #     print('===> 1')
    #     # name
    #     print('===> 2')
    #     l =[1,2,3]
    #     l[100]
    #     print('===> 3')
    #     d ={}
    #     d['name']
    #     print('===> 4')
    # except NameError as e:
    #     print(e)
    # except IndexError as e:
    #     print(e)
    # except KeyError as e:
    #     print(e)
    # except Exception as e:
    #     print('统一的处理方法!',e)
    # else:
    #     print('try内代码块没有异常则执行我')
    # finally:
    #     print('无论异常与否,都会执行该模块,通常是进行清理工作')
    #
    #
    # # 实例:  针对finally这种异常处理实例:主要还是对回收机制的处理
    # try:
    #     f = open('a.txt','r',encoding='utf-8')
    #     print(next(f),end='')
    #     print(next(f),end='')
    #     print(next(f),end='')
    #     print(next(f),end='')
    #
    #     print(next(f),end='')
    # finally:
    #     print('pppp')
    #     f.close()  #这里读了五次,第五次没有信息了
    #               #出来的结果就是读完文件里的信息之后,将第五次没有督导信息异常给抛出来
    

    ==五.主动触发异常:raise 异常类型(值)

    class People:
        def __init__(self,name,age):
            if  not isinstance(name,str): #判断name的值是不是str类型
                raise TypeError('名字必须传入str类型')
            if not isinstance(age, int):  # 判断name的值是不是str类型
                raise TypeError('年龄必须传入int类型')
            self.name = name
            self.age = age
    # p = People(333,18) #在name传入值得时候,他就传入333,就你管不住,就可以主动触发异常限制传入的name值不能为333
    p = People('alex',18) #这样动抛出异常可以限制,传入的值必须是什么类型
    # print(p.name)
    

    六.自定义异常

    class MyException(BaseException):
        def __init__(self,msg):
            super(MyException,self).__init__()
            self.msg=msg
    
        def __str__(self):
            return self.msg
    
    raise MyException('我自己的异常类型')
    #这一步是异常类型实例化得到的一个对象,他还会做一个打印这个对象的操作print(obj),
    # 会触发MyException对象的str方法,所以要想打印变得有意义就要写上 def __str__方法
    # raise除了把异常的追踪信息,和异常抛出来以后,还会打印这个对象的操作
    
    
    # Traceback (most recent call last):
    #   File "E:/模块三/考核/3_异常类之抛出异常.py", line 188, in <module>
    #     raise MyException('我自己的异常类型')  #print(obj)
    # __main__.MyException: 我自己的异常类型
    
    # 为了保证程序的健壮性与容错性,即在遇到错误时程序不会崩溃,我们需要对异常进行处理,
    # 如果错误发生的条件是可预知的,我们需要用if进行处理:在错误发生之前进行预防
    
  • 相关阅读:
    LODOP中用ADD_PRINT_IMAGE缩放非图片超文本
    LODOP关联,打印项序号注意事项
    LODOP在页面让客户选择打印机
    【JS新手教程】LODOP打印复选框选中的任务或页数
    映美FP-530K+打印发票的各种经验
    【JS新手教程】LODOP打印复选框选中的内容
    LODOP和C-LODOP注册与角色等简短问答【增强版】
    【JS新手教程】弹出两层div,及在LODOP内嵌上层
    LODOP内嵌挡住浏览器的div弹出层
    【JS新手教程】浏览器弹出div层1
  • 原文地址:https://www.cnblogs.com/sunny7/p/9716499.html
Copyright © 2020-2023  润新知