博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python3 的异常处理
阅读量:6655 次
发布时间:2019-06-25

本文共 1091 字,大约阅读时间需要 3 分钟。

Python3 的异常处理,在官方文档的  中有说明。

这里把常用的异常处理方法都列出来,方便平时查找。

捕获异常基类

Python3 要求我们的异常必须继承 Exception 类。Built-in 的所有异常也都是继承自这个类。因此,我们只需要捕获这个类的实例,就可以捕获所有的异常。

try:    raiseexcept Exception as err: print(err)

 

使用 sys.exc_info() 和 sys.last_traceback

sys.exc_info() 会返回一个3值元表,其中包含调用该命令时捕获的异常。

这个元表的内容为 (type, value, traceback) ,其中:

  • type 从获取到的异常中得到类型名称,它是BaseException 的子类;
  • value 是捕获到的异常实例;
  • traceback 是一个 traceback 对象,下面会详述。

sys.last_traceback 包含的内容与 sys.exc_info() 相同,但它主要用于调试,并不总是被定义。

import systry:    raiseexcept: t,v,tb = sys.exc_info() print(t,v)

使用 traceback

trackback 模块用来精确模仿 python3 解析器的 stack trace 行为。在程序中应该尽量使用这个模块。

traceback.print_exc() 可以直接打印当前的异常。

import tracebacktry:    raiseexcept: traceback.print_exc()

traceback.print_tb() 用来打印上面提到的 trackback 对象。

import sys,tracebacktry: raise except: t,v,tb = sys.exc_info() traceback.print_tb(tb)

traceback.print_exception() 可以直接打印 sys.exc_info() 提供的元表。

import sys,tracebacktry: raise except: traceback.print_exception(*sys.exc_info())

其实,下面两句是等价的:

  • traceback.print_exc()
  • traceback.print_exception(*sys.exc_info())

traceback 提供的参数可以将 print 的内容写入到文件中,详见这里:

转载地址:http://pqtto.baihongyu.com/

你可能感兴趣的文章
现在该怎么去做SEO?
查看>>
那些年,一起学的Java 9-2
查看>>
图片涂鸦
查看>>
去除linux文本和windows文本的换行和\0d的问题
查看>>
时间:2014年4月4日15:49:58 多文件上传
查看>>
时间:2014年4月13日19:01:06订单商品表写入
查看>>
linux网络第一季运维001
查看>>
快速配置Linux下的Vim编辑器
查看>>
浏览器缓存
查看>>
nginx的upstream目前支持5种方式的分配
查看>>
[Thinking in JAVA] 多态和继承的这潭深水
查看>>
Web前端网页开发,很不错时间选择框。
查看>>
dovecot vsz_limit参造成foxmail、outlook等客户端工具接收邮件有时候报错
查看>>
Apache Common-Lang HashCodeBuilder及EqualsBuilder分析
查看>>
C#改变按键的"键值"
查看>>
Shell脚本编程之Bash特性-IO重定向-变量
查看>>
东禹鲜锅-您的饮食乐趣
查看>>
windows系统常用快捷键
查看>>
简单实用log4j实现日志打印到控制台
查看>>
709B - 比特率、波特率、载波调制
查看>>