• python基础--异常处理


     、异常

    Python检测到一个错误时,解释器就无法继续执行了,反而出现了一些错误的提示,这就是所谓的"异常"

    1、python中标准异常

      BaseException 所有异常的基类

      SystemExit 解释器请求退出

      KeyboardInterrupt 用户中断执行(通常是输入^C)

    Exception 常规错误的基类

      StopIteration 迭代器没有更多的值

      GeneratorExit 生成器(generator)发生异常来通知退出

      StandardError 所有的内建标准异常的基类

      ArithmeticError 所有数值计算错误的基类

      FloatingPointError 浮点计算错误

      OverflowError 数值运算超出最大限制

      ZeroDivisionError (或取模)(所有数据类型)

      AssertionError 断言语句失败

      AttributeError 对象没有这个属性

      EOFError 没有内建输入,到达EOF 标记

      EnvironmentError 操作系统错误的基类

      IOError 输入/输出操作失败

    OSError 操作系统错误

      WindowsError 系统调用失败

      ImportError 导入模块/对象失败

      LookupError 无效数据查询的基类

      IndexError 序列中没有此索引(index)

      KeyError 映射中没有这个键

      MemoryError 内存溢出错误(对于Python 解释器不是致命的)

      NameError 未声明/初始化对象 (没有属性)

      UnboundLocalError 访问未初始化的本地变量

      ReferenceError 弱引用(Weak reference)试图访问已经垃圾回收了的对象

      RuntimeError 一般的运行时错误

      NotImplementedError 尚未实现的方法

      SyntaxError Python 语法错误

      IndentationError 缩进错误

      TabError Tab 和空格混用

      SystemError 一般的解释器系统错误

      TypeError 对类型无效的操作

      ValueError 传入无效的参数

      UnicodeError Unicode 相关的错误

      UnicodeDecodeError Unicode 解码时的错误

      UnicodeEncodeError Unicode 编码时错误

      UnicodeTranslateError Unicode 转换时错误

      Warning 警告的基类

      DeprecationWarning 关于被弃用的特征的警告

      FutureWarning 关于构造将来语义会有改变的警告

      OverflowWarning 旧的关于自动提升为长整型(long)的警告

      PendingDeprecationWarning 关于特性将会被废弃的警告

      RuntimeWarning 可疑的运行时行为(runtime behavior)的警告

      SyntaxWarning 可疑的语法的警告

      UserWarning 用户代码生成的警告

    2 、捕获异常

    异常语法:

      try:

      …

      except 异常类型 as 数据:

      …

      except 异常类型 as 数据:

      …

      else:

      无异常时执行

      finally:

      无论是否有异常,都会执行

     1 ## 解决异常方法1:条件判断
     2 def div(a, b):
     3     if b == 0:  ###
     4         print('b不能为0')  ##
     5         return  ##
     6     return a / b
     8 div(10, 0)
     9 
    11 
    12 ##解决办法2:捕获(特定)异常
    13 a = 10
    14 b = 10
    15 try:
    16     v = a / b
    17     # v1 = int('abc')## 出错了,才会处理异常
    18     print('---')  ## 没有执行,代码出错,不执行这一条
    19 except ZeroDivisionError:  # 捕获特定异常
    20     print('代码异常!!')  ##处理异常--- 程序不崩溃
    21 # except:##写法1
    22 #     print('捕获任意异常')##捕获通用异常
    23 except Exception as e:  ##写法2
    24     print('捕获任意异常=', e)  ##捕获通用异常,可以输出异常!!!!
    25 
    26 else:  ## 没有异常,执行后面的代码
    27     print('没有异常')
    28 
    29 finally:  ## 有没有异常都会执行
    30     print('有咩有异常,都会进来执行')
    31 
    32 print('---------------')
    33 
    34 ### 在函数中捕获异常
    35 def div(a, b):
    36     try:
    37         v = a / b
    38         return v  ## 函数结束后,执行了finally才回去
    39     except:
    40         print('error')
    41     finally:  ## 就算函数return,也会执行finally才结束!!!!
    42         print('finally')
    44 
    45 div(10, 10)
    46 
    47 ## 解决办法3:
    48 ## 主动触发异常!! 不是代码错误
    49 ## 自己无法处理,交给其他人处理
    50 ## 自己触发!!! ---相当于通信
    51 
    52 def div2(a, b):
    53     if b == 0:
    54         raise ZeroDivisionError('除以0了')
    55     ## raise  后面的代码不会执行
    56     return a / b
    57 
    58 
    59 ## raise的异常,必须捕获处理
    60 try:
    61     print(div2(10, 0))
    62 except Exception as e:
    63     print(e)

    3、 主动触发异常(抛出异常)

      本身处理不了,交给其他人处理

      语法:raise 异常

     1 ##异常处理
     2 
     3 
     4 ## 解决异常方法1:条件判断
     5 def div(a ,b):
     6     if b==0:  ###
     7         print('b不能为0')##
     8         return##
     9     return a/b 
    10 
    11 div(10,0)
    12 
    13 ##解决办法2:捕获(特定)异常
    14 a = 10
    15 b = 10
    16 try:
    17     v = a/b
    18     # v1 = int('abc')## 出错了,才会处理异常
    19     print('---') ## 没有执行,代码出错,不执行这一条
    20 except ZeroDivisionError:#捕获特定异常
    21     print('代码异常!!')##处理异常--- 程序不崩溃
    22 # except:##写法1
    23 #     print('捕获任意异常')##捕获通用异常
    24 except Exception as e:##写法2
    25     print('捕获任意异常=',e)##捕获通用异常,可以输出异常!!!!
    26 
    27 else: ## 没有异常,执行后面的代码
    28     print('没有异常')
    29 
    30 finally:## 有没有异常都会执行
    31     print('有咩有异常,都会进来执行')
    32 
    33 print('---------------')
    34 
    35 
    36 
    37 ### 在函数中捕获异常
    38 def div(a ,b):
    39     try:
    40         v = a/b 
    41         return v  ## 函数结束后,执行了finally才回去
    42     except:
    43         print('error')
    44     finally: ## 就算函数return,也会执行finally才结束!!!!
    45         print('finally')
    46 
    47 div(10,10)
    48 
    49 
    50 
    51 ## 解决办法3:
    52 ## 主动触发异常!! 不是代码错误
    53 ## 自己无法处理,交给其他人处理
    54 ## 自己触发!!! ---相当于通信
    55 
    56 def div2(a,b):
    57     if b ==0:
    58         raise ZeroDivisionError('除以0了')
    59         ## raise  后面的代码不会执行
    60     return a/b
    61 
    62 ## raise的异常,必须捕获处理
    63 try:
    64     print(div2(10,0))
    65 except Exception as e:
    66     print(e) 
        print(e.args) ##这里的异常是个元祖() 保存出错信息

    4、 自定义异常

      自定义异常就是:写一个类继承自Exception, 用于同一处理异常

     1 ## 假设一个用户登录的需求,需要接受到用于当前操作的结果
     2 
     3 ## 一般情况和下有两种解决方案:
     4 ## 1、根据返回值
     5 def login(name ,password):
     6     if name = 'admin' :
     7          if pwd == '123':
     8             print(‘登录成功’)
     9             return True
    10          else11              print('密码错误')
    12              return Flase
    13     else:
    14         print('用户名错误')
    15         return Flase
    16 
    17 
    18 ## 2、自定义异常
    19 class MyException(Exception):
    20     def __init__(self,code):
    21         self.code = code
    22 
    23 ## 主动抛出异常,处理
    24 def login(name,pwd):
    25     if name =='admin':
    26         if pwd =='123':
    27            print('登录成功')
    28         else29            raise MyException(101)
    30     else:
    31          raise MyException(102)
    32 
    33 ## 处理异常
    34 dic = {101:'密码错误',102:'姓名错误'}
    35 try36     login('admin','1234')
    37 except MyExcept as e:
    38     print(e)   ## 输出101,但是它的类型无法处理!!
    39     print(type(e)) ## 输出:<class '__main__.MyExcept'>
    40     print(e.args) ##输出:通过args获取创建异常对象时传的参数,元祖
    41     print(dic[e.args[0]]) ## 得到101,就可以同一处理
    有生之年,只诉衷肠不言殇.....
  • 相关阅读:
    mysql优化之索引优化
    mysqld --debug-sync
    mysql.cnf 配制文件详解
    my.cnf 中字符集设置
    tcp_tw_reuse 与 net.ipv4.tcp_tw_recycle
    mysql init_connect 参数的其他用处
    监控mysql索引使用效率的脚本
    mysql 源代码学习 博客 [lock..]
    mysqld with valgrind
    思维导图软件
  • 原文地址:https://www.cnblogs.com/dyl01/p/8534873.html
Copyright © 2020-2023  润新知