zoukankan      html  css  js  c++  java
  • 异常处理

    异常处理

    1. 错误分类

    # 1.语法错误: SyntaxError:invalid syntax
    if 2>3
    	pass
    
    # 2.逻辑错误: 用异常处理
    

    2. 异常

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

    3. 异常处理

       当代码出现异常时,通过某种方式不让程序中断,合理的“跳”过去。
       
    好处:
    	1. 为了使用户体验良好
    	2. 使代码更有健壮性、容错性
    

    4. 异常处理的两种方法

    	1.if:只能处理简单的异常,如果异常需要考虑的方面比较多时,不合适
    	2. try: 当出现异常时,就会跳转到except。
    语法:
    try:
         被检测的代码块
    except 异常类型:
         try中一旦检测到异常,就执行这个位置的逻辑
    

    5. try的结构

    5.1 结构一:单分支结构

    # 只处理一种错误,如果未捕获到异常,程序直接报错
    
    try:
        dic = {'name':'meet'}
        print(dic['age'])
    except KeyError:
        break
    

    5.2 结构二:多分支结构

    # except多个错误,从上到下,当出现错误就会结束
    
    s1 = 'hello'
    try:
        int(s1)
    except IndexError as e:
        print(e)
    except KeyError as e:
        print(e)
    except ValueError as e:
        print(e)		# 执行
    # invalid literal for int() with base 10: 'hello'
    
    

    5.3 结构三:万能异常

    # Exception, 处理所有python识别的异常
    
    s1 = 'hello'
    try:
        int(s1)
    except Exception as e:
        print(e)
    
    什么时候用万能? 什么时候用多分支?
    	如果你对错误信息不关心,只是想要排除错误让程序继续运行,用万能异常.
    	如果你对错误信息要进行明确的分流,让你的程序多元化开发,使用分支
    

    5.4 结构四:多分支+万能异常

    # 满足多元化开发,并且排除其他不需要的错误。
    
    def func():
        print('in func')
    
    def func1():
        print('in func1')
        
    dic = {
        1: func,
        2: func1,
    }
    
    try:
        num = int(input('请输入序号:'))
        dic[num]()
    except ValueError:
        print('请输入数字!')
    except KeyError:
        print('请输入范围内的序号!')
    except Exception:
        print('程序出现错误...')
    

    5.5 结构五: try else finally

    try:
        dic = {'name': 'meet'}
        # print(dic['age'])
        l1 = [1, 2]
        # print(l1[100])
        print(111)
    except KeyError:
        print('没有此键')
    except IndexError:
        print('没有此下标')
    else:
        print('如果没有出现异常则执行这里')
    finally:
        print('in finally')
    
        
    # except 必须依赖try
    # else: 必须依赖try和except
    # finally: 只依赖try
    
    # else:
    	如果没有出现异常,则执行;有异常执行except--.
        
    # finally:
    	在异常出现之前,执行finall语句。
        用在关闭数据库连接、文件句柄关闭、数据保存等.
        在return结束函数之前或者break结束循环之前,也可先执行finally语句。
        
    with open('test', 'r+', encoding='utf-8') as f1:
        try:
            for i in f1:
                print(i)
            if ...:
               	pass  
        finally:
            f1.close()
    # 当在对文件操作时,如果中途出现错误时,就会用finally关闭文件,从而消除内存。
    

    5.6 结构六: 主动触发异常

    raise ValueError('出现了ValueError错误!')
    

    5.7 结构七: 断言

    # 展现出一种强硬的态度
    
    assert 条件
    ...
    
    # 条件不成立,后面的代码不执行,直接报错
    # AssertionError
    

    5.8 结构八: 自定义异常

    # python中提供的错误类型很多,但是不是全部的错误,因此有的出错误不能用Exception捕获。
    # 自定义异常必须继承 BaseException
    
    class EvaException(BaseException):
        def __init__(self,msg):
            self.msg=msg
        def __str__(self):
            return self.msg
    
    try:
        raise EvaException('类型错误') #实例化
    except EvaException as e:
        print(e)
    

    6. try..except比较if的好处:

    try..except这种异常处理机制就是取代if那种方式,让你的程序在不牺牲可读性的前提下增强健壮性和容错性.
    
    异常处理中为每一个异常定制了异常类型(python中统一了类与类型,类型即类),对于同一种异常,一个except就可以捕捉到,可以同时处理多段代码的异常(无需‘写多个if判断式’)减少了代码,增强了可读性 
    
    使用try..except的方式:
    
    1:把错误处理和真正的工作分开来
    2:代码更易组织,更清晰,复杂的工作任务更容易实现;
    3:毫无疑问,更安全了,不至于由于一些小的疏忽而使程序意外崩溃了;
    

    附录:错误类型

    ZeroDivisionError 	除(或取模)零 (所有数据类型)
    ValueError 	传入无效的参数
    AssertionError 	断言语句失败
    StopIteration 	迭代器没有更多的值
    IndexError 	序列中没有此索引(index)
    IndentationError 	缩进错误
    OSError 	输入/输出操作失败
    ImportError 	导入模块/对象失败
    NameError 	未声明/初始化对象 (没有属性)
    AttributeError 	对象没有这个属性
      	 
    GeneratorExit 	生成器(generator)发生异常来通知退出
    TypeError 	对类型无效的操作
    KeyboardInterrupt 	用户中断执行(通常是输入^C)
    OverflowError 	数值运算超出最大限制
    FloatingPointError 	浮点计算错误
    BaseException 	所有异常的基类
    SystemExit 	解释器请求退出
    Exception 	常规错误的基类
    StandardError 	所有的内建标准异常的基类
    ArithmeticError 	所有数值计算错误的基类
    EOFError 	没有内建输入,到达EOF 标记
    EnvironmentError 	操作系统错误的基类
    WindowsError 	系统调用失败
    LookupError 	无效数据查询的基类
    KeyError 	映射中没有这个键
    MemoryError 	内存溢出错误(对于Python 解释器不是致命的)
    UnboundLocalError 	访问未初始化的本地变量
    ReferenceError 	弱引用(Weak reference)试图访问已经垃圾回收了的对象
    RuntimeError 	一般的运行时错误
    NotImplementedError 	尚未实现的方法
    SyntaxError Python 	语法错误
    TabError 	Tab 和空格混用
    SystemError 	一般的解释器系统错误
    UnicodeError 	Unicode 相关的错误
    UnicodeDecodeError 	Unicode 解码时的错误
    UnicodeEncodeError 	Unicode 编码时错误
    UnicodeTranslateError 	Unicode 转换时错误
    
    以下为警告类型 :	 
    Warning 	警告的基类
    DeprecationWarning 	关于被弃用的特征的警告
    FutureWarning 	关于构造将来语义会有改变的警告
    OverflowWarning 	旧的关于自动提升为长整型(long)的警告
    PendingDeprecationWarning 	关于特性将会被废弃的警告
    RuntimeWarning 	可疑的运行时行为(runtime behavior)的警告
    SyntaxWarning 	可疑的语法的警告
    UserWarning 	用户代码生成的警告
    
  • 相关阅读:
    SAP-MM采购视图-利润中心在“工厂数据/存储2”
    SAP-物料主数据维护之(通用名称/商用名称维护)
    SAP BP维护客商主数据之(交货与付款条件)定义
    SAP MM01创建物料时配置价格
    SAP SD后台配置清单
    SAP- 物料主数据之多工厂设置
    SAP如何查询表名及字段
    SAP学习之:F-65制作财务客户收款凭证
    SAP中创建采购信息记录 (ME11)
    SAP DEV-Q-PRO系统环境默认配置规则
  • 原文地址:https://www.cnblogs.com/liwenhu/p/11401585.html
Copyright © 2011-2022 走看看