• Python -- 异常处理


    7.9 异常处理

    什么是异常? -- 程序出现中断,飘红,致使整个项目中断.

    什么是异常处理? -- 一旦程序出现异常,异常处理会即使的捕捉到你的错误,不至于你的程序崩溃,并进行了程序分流.

    为什么要进行异常处理? -- 通过异常处理机制增强程序的健壮性和容错性.

    错误类型: 1.语法错误 2.逻辑错误

    # 常用异常
    
    AttributeError # 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x
    IOError # 输入/输出异常;基本上是无法打开文件
    ImportError # 无法引入模块或包;基本上是路径问题或名称错误
    IndentationError # 语法错误(的子类) ;代码没有正确对齐
    IndexError # 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]
    KeyError # 试图访问字典里不存在的键
    KeyboardInterrupt # Ctrl+C被按下
    NameError # 使用一个还未被赋予对象的变量
    SyntaxError # Python代码非法,代码不能编译(个人认为这是语法错误,写错了)
    TypeError # 传入对象类型与要求的不符合
    UnboundLocalError # 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,导致你以为正在访问它
    ValueError # 传入一个调用者不期望的值,即使值的类型是正确的
    
    # 更多异常
    ArithmeticError
    AssertionError
    AttributeError
    BaseException
    BufferError
    BytesWarning
    DeprecationWarning
    EnvironmentError
    EOFError
    Exception
    FloatingPointError
    FutureWarning
    GeneratorExit
    ImportError
    ImportWarning
    IndentationError
    IndexError
    IOError
    KeyboardInterrupt
    KeyError
    LookupError
    MemoryError
    NameError
    NotImplementedError
    OSError
    OverflowError
    PendingDeprecationWarning
    ReferenceError
    RuntimeError
    RuntimeWarning
    StandardError
    StopIteration
    SyntaxError
    SyntaxWarning
    SystemError
    SystemExit
    TabError
    TypeError
    UnboundLocalError
    UnicodeDecodeError
    UnicodeEncodeError
    UnicodeError
    UnicodeTranslateError
    UnicodeWarning
    UserWarning
    ValueError
    Warning
    ZeroDivisionError
    

    如何进行异常处理?

    7.8.1 使用if判断式

    1.if判断式的异常处理只能针对某一段代码,对于不同的代码段的相同类型的错误你需要写重复的if来进行处理。

    2.在你的程序中频繁的写与程序本身无关,与异常处理有关的if,会使得你的代码可读性极其的差

    3.if是可以解决异常的,只是存在1,2的问题,所以,千万不要妄下定论if不能用来异常处理。

    7.8.2 Python异常处理的'私人订制'

    # 基本语法
    try:
    	被检测代码块
    except 异常类型:
        pass
    # try一旦检测到异常,就执行pass这个位置的逻辑
    
    # 单分支
    try:
        l = [1,2,3]
        print(l[5])
        
        dic = {1:'a',2:'b'}
        print(dic[3])
        
        num = input('输入数字')
        int(num)
        
    except IndexError as e:
        print(e) # list index out of range
        
    print(111)  # 依然会执行
    # 如果第一部分代码没有出现异常,在执行字典代码的时候,依然会报错
    
    # 多分支
    try:
        l = [1,2,3]
        print(l[5])
        
        dic = {1:'a',2:'b'}
        print(dic[3])
        
        num = input('输入数字')
        int(num)
        
    except IndexError as e:
        print(e)
    except KeyError as e:
        print(e)
    except ValueError as e:  # 满足一个错误类型,下面就不执行了,跳转到print
        print('出现了转化错误')
        
    print(111)
    
    
    dic = {1:111,
           2:222,
           3:333}
    
    while 1:
        try:
            num = input('请输入序号')
            int(num)
            print(dic[int(num)])
    
        except KeyError as e:
            print('选项超出范围')
    
        except ValueError as e:
            print('请输入数字')
    
    # 万能异常
    dic = {1:111,
           2:222,
           3:333}
    try:
        num = input('请输入序号')
        int(num)
        print(dic[int(num)])
    
    except Exception as e:
        print(e)
    print(111)
    

    什么时候用万能异常,什么时候用多分支?

    • 如果你只是想把异常处理掉,让程序继续执行,用万能异常
    • 如果出现了异常,想根据不同的异常执行不同的逻辑流程,用多分支
    # 万能加,多分支混合
    while 1:
        try:
            num = input('请输入序号')
            int(num)
            print(dic[int(num)])
    
        except KeyError as e:
            print('选项超出范围')
        except ValueError as e:
            print('请输入数字')
        except Exception:  # 一定写在最下面
            pass
    

    7.8.3 异常处理的其他成员

    else finally assert raise

    # try ... else  不能单独使用,必须和except结合
    try:
    	num = input('请输入序号')
    	int(num)
    	print(dic[int(num)])
        
    except KeyError as e:
        print('选项超出范围')
    except Exception: 
        pass
    else: # 如果上面无异常,执行else语句,否则不还行else语句
        print(111)
        
        
    try:
    	num = input('请输入序号')
    	int(num)
    	print(dic[int(num)])
        
    except KeyError as e:
        print('选项超出范围')
    except Exception: 
        pass
    finally: # 在异常发生之前执行finally (关闭文件句柄,关闭连接,引擎)
        print(111)
    
    # 举例
    try:
        f = open('register', mode='w')
        f.write('fdjsaklfd')
        f.write('fdjsaklfd')
        f.write('fdjsaklfd')
        l1 = [1, 2, 3]
        print(111)
        print(l1[1000])
        f.write('fdjsaklffjdsklaf')
    finally:
        print('哈哈哈哈')
        f.close()
        
    def func():  # 面试题
        try:
            a = 1
            b = 2
            return a + b
        finally:   # 在函数结束之前先打印666
            print(666)
    func()
    
    # 主动抛出异常
    raise Exception('返回内容')
    
    # 断言
    assert + 条件    # 格式
    
    assert 1 == 1  # 如果条件成立,执行下面代码
    print(11)
    assert 1 == 2  # 如果条件不成立,会报错,不执行
    print(22)   
    
    # 自定义异常 (了解)
    class Connection(BaseException):
        def __init__(self,msg):
            self.msg=msg
    
    raise Connection('出发了链接异常')
    

    异常处理总结:

    异常处理不能经常使用:异常处理耗费性能,有些错误是需要进行分流使用的,代码的可读性变差,在关键的节点使用.

    使用try..except的方式的好处:

    • 把错误处理和真正的工作分开来
    • 代码更易组织,更清晰,复杂的工作任务更容易实现
    • 更安全,不至于由于一些小的疏忽而使程序意外崩溃

    什么时候用异常处理:

    尽量少用,只有在有些异常处理无法预知的情况下,(某些位置if太多)再用异常处理

  • 相关阅读:
    Zookeeper简介
    ArrayList
    Java数据类型的零碎知识
    Cookie/Session/Token对比
    布隆过滤器(Bloom Filter)
    Spring MVC简介
    Spring简介
    win10系统64位安装git后右键运行git bash here生成一个mintty.exe.stackdump文件后闪退解决方案
    CSS属性速查表
    Sublime text3中配置Github
  • 原文地址:https://www.cnblogs.com/Agoni-7/p/11215102.html
Copyright © 2020-2023  润新知