Python3 的异常处理

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

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

捕获异常基类

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

try:
    raise
except 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 sys
try:
    raise
except:
    t,v,tb = sys.exc_info()
    print(t,v)

使用 traceback

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

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

import traceback
try:
    raise
except:
    traceback.print_exc()

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

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

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

import sys,traceback
try:
    raise
except:
    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

原文地址:https://www.cnblogs.com/php-linux/p/8322184.html

时间: 2024-08-28 17:17:40

Python3 的异常处理的相关文章

【Python3之异常处理】

一.错误和异常 1.错误 代码运行前的语法或者逻辑错误 语法错误(这种错误,根本过不了python解释器的语法检测,必须在程序执行前就改正) def test: ^ SyntaxError: invalid syntax #语法错误示范 def test: pass #语法错误示范 class Foo pass #语法错误示范 print(haha 其他语法错误 逻辑错误 #用户输入不完整(比如输入为空)或者输入非法(输入不是数字) num=input(">>: ") in

python3之异常处理(转)

一.错误和异常 1.错误 代码运行前的语法或者逻辑错误 语法错误(这种错误,根本过不了python解释器的语法检测,必须在程序执行前就改正) def test: ^ SyntaxError: invalid syntax  其他语法错误 逻辑错误 #用户输入不完整(比如输入为空)或者输入非法(输入不是数字) num=input(">>: ") int(num) 输出 >>: fsf Traceback (most recent call last): File

python3之异常处理

1.语法错误与异常 (1)语法错误 Python 的语法错误或者称之为解析错,是初学者经常碰到的,如下实例: >>> while True print('Hello world') File "<stdin>", line 1, in <module> while True print('Hello world') ^ SyntaxError: invalid syntax 这个例子中,函数 print() 被检查到有错误,是它前面缺少了一个冒

python3的异常处理

在python运行的时候难免出现一些异常,但是python在遇到异常的时候就会停止了,但是有时候我们需要python即使在有异常的时候也需要继续向下运行,这个时候我们就需要用到异常处理了.1.简单的异常处理如: print(a) Traceback (most recent call last): File "<input>", line 2, in <module> NameError: name 'a' is not defined 我们在没有定义变量a的时

Python3中urllib详细使用方法(header,代理,超时,认证,异常处理) 转载

urllib是python的一个获取url(Uniform Resource Locators,统一资源定址器)了,我们可以利用它来抓取远程的数据进行保存哦,下面整理了一些关于urllib使用中的一些关于header,代理,超时,认证,异常处理处理方法,下面一起来看看. python3 抓取网页资源的 N 种方法 1.最简单 import urllib.requestresponse = urllib.request.urlopen('http://python.org/')html = res

Python3学习之异常处理详解

本文和大家分享的主要是python3中的异常及相关解决方法,一起来看看吧,希望对大家学习python3有所帮助. 一.错误和异常 1.错误 代码运行前的语法或者逻辑错误 . 语法错误(这种错误,根本过不了python解释器的语法检测,必须在程序执行前就改正) def test: ^ SyntaxError: invalid syntax #语法错误示范def test: pass #语法错误示范class Foo pass #语法错误示范 print(haha 其他语法错误 . 逻辑错误 #用户

【转】Python3中urllib详细使用方法(header,代理,超时,认证,异常处理)

urllib是python的一个获取url(Uniform Resource Locators,统一资源定址器)了,我们可以利用它来抓取远程的数据进行保存哦,下面整理了一些关于urllib使用中的一些关于header,代理,超时,认证,异常处理处理方法,下面一起来看看. python3 抓取网页资源的 N 种方法 1.最简单 1 import urllib.request 2 3 response = urllib.request.urlopen('http://python.org/') 4

Python3中urllib详细使用方法(header,代理,超时,认证,异常处理)

urllib是python的一个获取url(Uniform Resource Locators,统一资源定址器)了,我们可以利用它来抓取远程的数据进行保存哦,下面整理了一些关于urllib使用中的一些关于header,代理,超时,认证,异常处理处理方法,下面一起来看看. python3 抓取网页资源的 N 种方法 1.最简单 1 import urllib.request 2 3 response = urllib.request.urlopen('http://python.org/') 4

python3.x的异常处理

以前的python2.x的时候: try: fp=urllib.request.urlopen(blogurl) except Exception, e: print (e) print('download exception %s' % blogurl) return 0 现在python3.x的时候: try: fp=urllib.request.urlopen(blogurl) except Exception as e: print (e) print('download excepti