try异常处理

为了处理异常,使用try...except,把可能发生错误的语句放在try模块里,用except来处理异常。except可以处理一个专门的异常,也可以处理一组圆括号中的异常,如果except后没有指定异常,则默认处理所有的异常。每一个try,都必须至少有一个except。
在python的异常中,有一个万能异常:Exception,可以捕获任意异常:

s1 = 'hello'
try:
  int(s1)
except Exception,e:
  print(e)

需要考虑到try代码块中可能出现的多个异常,可以这样写:

s1 = 'hello'
try:
  int(s1)
except IndexError,e:
  print(e)
except KeyError,e:
  print(e)
except ValueError,e:
  print(e)

异常的简单结构和复杂结构

try:
  pass
except Exception as e: #python2 中还可以这样写:except Exception,e
  pass

完整实列:

try:
  # 主代码块
  pass
except KeyError,e:
  # 异常时,执行该块
  pass
else:
  # 主代码块执行完,执行该块
  pass
finally:
  # 无论异常与否,最终执行该块
  pass

先定义特殊提醒的异常,最后定义Exception,来确保程序正常运行。
先特殊,后万能

s1 = 'hello'
try:
  int(s1)
except KeyError,e:
  print('键错误')
except IndexError,e:
  print('索引错误')
except Exception, e:
  print('错误')

主动触发异常:raise Exception('messages')可以自定义报错信息

a=2
if a > 1:
  raise ValueError('值大于1')

raise 触发异常

try:
  raise Exception('错误了。。。')
except Exception,e:
  print e

自定义异常

class XXXXXException(Exception):
  def __init__(self, msg):
    self.message = msg
  def __str__(self):
    return self.message
try:
  raise XXXXXException('我的异常')
except XXXXXException,e:
  print(e)

python所有的标准异常类

  • BaseException:所有异常的基类
    • SystemExit:解释器请求退出
    • KeyboardInterrupt:用户中断执行(通常是输入^C)
    • GeneratorExit:生成器(generator)发生异常来通知退出
    • Exception:常规错误的基类
      • StopIteration:迭代器没有更多的值
      • StopAsyncIteration:异步迭代器对象停止迭代
      • ArithmeticError:所有数值计算错误的基类
        • FloatingPointError:浮点计算错误
        • OverflowError:数值运算超出最大限制
        • ZeroDivisionError:除(或取模)零 (所有数据类型)
      • AssertionError:断言语句失败
      • AttributeError:对象没有这个属性
      • BufferError:当无法执行与缓冲区相关的操作时引发
      • EOFError:没有内建输入,到达EOF标记
      • ImportError:导入模块/对象失败
        • ModuleNotFoundError:在找不到模块时由import引发,当在系统模块中找不到时也会引发此问题
      • LookupError:无效数据查询的基类
        • IndexError:序列中没有没有此索引(index)
        • KeyError:映射中没有这个键
      • MemoryError:内存溢出错误(对于Python解释器不是致命的)
      • NameError:未声明/初始化对象 (没有属性)
        • UnboundLocalError:访问未初始化的本地变量
      • OSError:操作系统错误
        • BlockingIOError:当一个操作将阻塞为非阻塞操作设置的对象(如套接字)时引发
        • ChildProcessError:子进程上的操作失败时引发
        • ConnectionError:连接相关问题的基类
          • BrokenPipeError:当试图在管道上写而另一端已关闭时,或试图在已关闭以进行写的套接字上写时引发
          • ConnectionAbortedError:当对等方中止连接尝试时引发
          • ConnectionRefusedError:当对等方拒绝连接尝试时引发
          • ConnectionResetError:当对等方重置连接时引发
        • FileExistsError:试图创建已经存在的文件或目录时引发
        • FileNotFoundError:当请求文件或目录但不存在时引发
        • InterruptedError:当系统调用被传入信号中断时引发
        • IsADirectoryError:在目录上请求文件操作(如os.remove())时引发
        • NotADirectoryError:当在非目录上请求目录操作(如os.listdir())时引发
        • PermissionError:试图在没有足够访问权限的情况下运行操作时引发,例如文件系统权限
        • ProcessLookupError:当给定的进程不存在时引发
        • TimeoutError:当系统功能在系统级别超时时引发
      • ReferenceError:弱引用(Weak reference)试图访问已经垃圾回收了的对象
      • RuntimeError:一般的运行时错误
        • NotImplementedError:尚未实现的方法
        • RecursionError:此异常源自运行时错误。当解释器检测到超过了最大递归深度(请参见sys.getrecursionlimit())时,将引发该事件。
      • SyntaxError:Python语法错误
        • IndentationError:缩进错误
          • TabError:Tab和空格混用
      • SystemError:一般的解释器系统错误
      • TypeError:对类型无效的操作
      • ValueError:传入无效的参数
        • UnicodeError:Unicode相关的错误
          • UnicodeDecodeError:解码时的错误
          • UnicodeEncodeError:编码时错误
          • UnicodeTranslateError:转换时错误
      • Warning:警告的基类
        • DeprecationWarning:关于被弃用的特征的警告
        • PendingDeprecationWarning:关于特性将会被废弃的警告
        • RuntimeWarning:可疑的运行时行为(runtime behavior)的警告
        • SyntaxWarning:可疑的语法的警告
        • UserWarning:用户代码生成的警告
        • FutureWarning:关于构造将来语义会有改变的警告
        • ImportWarning:关于模块导入中可能错误的警告的基类
        • UnicodeWarning:与Unicode相关的警告的基类
        • BytesWarning:与字节和字节数组相关的警告的基类
        • ResourceWarning:与资源使用相关的警告的基类。被默认警告过滤器忽略