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

    Python异常处理    >>>思维导图>>>中二青年

    什么是异常处理?

    程序在运行过程中出现了不可预知的错误

    并且该错误没有对应的处理机制,那么就会以异常的形式表现出来

    造成的影响就是整个程序无法正常运行

    异常的结构

    1.异常的类型:NAMEERROR

    2.异常的信息:name 'abc' is not defined

    3.异常的位置:Traceback (most recent call last): File "路径", line 1, in <module> abc

    异常的种类:

    1.语法错误
    是你程序立刻就能解决的,这种错误是不能被容忍的,语法上的错误,发现之后应该立刻解决

    2.逻辑错误
    这种错误是可以被容忍的,因为一眼看不出来,针对逻辑上的错误,可以采用异常处理机制进行捕获

    常见的错误类型

    NameError     名字错误

    SyntaxError    语法错误

    KeyError         健不存在

    valueError      值错误

    IndexError      索引错误

    TypeError       类型错误

    异常处理

    在你认为可能出现bug的代码块上方try一下

    try:
        可能出错的代码
    except 出错的类型 as e:  # 将报错信息赋值给变量e
        出错之后的处理机制

    注意try内部的代码块越少越好

    try后可跟多种except异常类型的捕获,但是不会连续连续捕获,因为有一个错误发生之后,会立刻停止代码的运行,执行该类型错误的except语句

    try:
        name
        l = [1,2,3]
        l[111]
        d = {'name':'jason'}
        d['password']
    except NameError:
        print('NameError')
    except IndexError:
        print('indexerror')
    except KeyError:
        print('keyerror')

    Exception 所有异常的基类,所有异常类型都被捕获

    try:
        # name
        l = [1,2,3]
        l[111]
        # d = {'name':'jason'}
        # d['password']
    except Exception:  # 万能异常  所有的异常类型都被捕获
        print('老子天下无敌')
    else:
        print('被检测的代码没有任何的异常发生 才会走else')
    finally:
        print('无论被检测的代码有没有异常发生 都会在代码运行完毕之后执行我')

    except后可跟else 被检测代码没有任何异常才会走else

    except后可跟finally 被检测代码无论有没有异常都会走finally

    raise 主动抛出异常

    if 'egon' == 'DSB':
        pass
    else:
        raise TypeError('尽说大实话')

    assert 断言、语言,猜某个数据的状态,猜对了不影响代码执行,猜错了直接报错

    l = [1,2,3]
    assert len(l) < 0  # 断言  预言

    自定义异常

    class MyError(BaseException):
         def __init__(self,msg):
             super().__init__()
             self.msg=msg
         def __str__(self):
             return '<dfsdf%ssdfsdaf>' %self.msg
    raise MyError('我自己定义的异常')  # 主动抛出异常其实就是将异常类的对象打印出来,会走__str__方法

    END

  • 相关阅读:
    VUE学习日记(十八) ---- 传递数据
    VUE学习日记(十七) ---- 组件数据函数
    VUE学习日记(十六) ---- 表行组件
    DataGridView控件使用Demo
    C# ADO.NET连接字符串详解
    SQL Server management studio使用sa连接时报错与伺服器的连接已成功,但在登入程序是发生错误
    Oracle Rac to Rac One Node
    online创建索引中途取消导致索引无法删除解决办法
    oracle常用hint添加
    C# url的编码解码,xml和json的序列化和反序列化
  • 原文地址:https://www.cnblogs.com/renvip/p/11322367.html
Copyright © 2011-2022 走看看