Python3 的异常处理
来源:互联网 发布:黑马java 全套百度云 编辑:程序博客网 时间:2024/06/06 02:56
Python3 的异常处理,在官方文档的 tutorial 中有说明。
这里把常用的异常处理方法都列出来,方便平时查找。
捕获异常基类
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: raiseexcept: t,v,tb = sys.exc_info() traceback.print_tb(tb)
traceback.print_exception()
可以直接打印 sys.exc_info()
提供的元表。
import sys,tracebacktry: raiseexcept: traceback.print_exception(*sys.exc_info())
其实,下面两句是等价的:
traceback.print_exc()
traceback.print_exception(*sys.exc_info())
traceback 提供的参数可以将 print 的内容写入到文件中,详见这里:29.9. traceback — Print or retrieve a stack traceback
来源:http://zengrong.net/post/2143.htm
1 0
- Python3 的异常处理
- Python3 的异常处理
- python3的异常处理
- python3.x的异常处理
- python3 爬取网页的异常处理
- Python3.2 --- 异常处理
- Python3 异常处理
- Python3 异常处理
- Python3 异常处理
- Python3之异常处理
- python3 异常处理
- python3 异常及异常处理
- Python3:异常处理,try...except
- Python3.X中的异常处理
- python3--异常处理及习题
- Python3学习(29)--异常处理
- python3的异常处理、操作excel和数据库
- python3.5处理异常与python2的不同
- Salvation(dfs)
- 算法时间复杂度分析(1)
- 散列表的基本原理与实现
- Payment:支付的回调统一处理
- OJ编程题教训
- Python3 的异常处理
- Itween笔记(第三节)
- android app冷启动
- runtime实战(二)动态添加方法
- CodeForces 731 E.Funny Game(dp)
- API管理,改变云计算、大数据和物联网的游戏规则
- OGNL与ValueStack(VS)-N语法top语法
- 百炼4106:出现两次的字符-Characters Appearing twice
- 学习笔记——Java