Python 获取异常信息

异常信息的获取对程序调试很重要,有助于快速定位错误语句位置。本文介绍了Python中获取异常信息的几种方法,采用try…except…程序结构,包括str(e)、repr(e)以及使用traceback模块,还说明了traceback模块不同方法的区别和用法。

本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理。

PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取

python免费学习资料以及群交流解答点击即可加入

作者:文渊博客

原文链接:  https://www.wenyuanblog.com/blogs/python-get-the-exception-value.html

异常信息的获取对于程序的调试非常重要,可以有助于快速定位有错误程序语句的位置。下面介绍几种 Python 中获取异常信息的方法,这里获取异常(Exception)信息采用 try…except… 程序结构。

如下所示:

try:
    print(x)
except Exception as e:
    print(e)

1. str(e)

返回字符串类型,只给出异常信息,不包括异常信息的类型,如:

try:
    print(x)
except Exception as e:
    print(str(e))

打印结果:

name 'x' is not defined

2. repr(e)

给出较全的异常信息,包括异常信息的类型,如:

try:
    print(x)
except Exception as e:
    print(repr(e))

打印结果:

NameError("name 'x' is not defined",)

一般情况下,当我们知道异常信息类型后,可以对异常进行更精确的捕获,如:

try:
    print(x)
except NameError:
    print('Exception Type: NameError')
except Exception as e:
    print(str(e))

3. 采用 traceback 模块

需要导入 traceback 模块,此时获取的信息最全,与 Python 命令行运行程序出现错误信息一致。

用法:使用 traceback.print_exc() 或 traceback.format_exc() 打印错误。

区别: traceback.print_exc() 直接打印错误, traceback.format_exc() 返回字符串。

示例如下:

import traceback

try:
    print(x)
except Exception as e:
    traceback.print_exc()

等价于:

import traceback

try:
    print(x)
except Exception as e:
    msg = traceback.format_exc()
    print(msg)

打印结果都是:

Traceback (most recent call last):
  File "E:/study/python/get_exception.py", line 4, in <module>
    print(x)
NameError: name 'x' is not defined

traceback.print_exc() 还可以接受 file 参数直接写入到一个文件。比如:

# 写入到 tb.txt 文件中
traceback.print_exc(file=open('tb.txt','w+'))

 

### 获取 Python 异常信息 traceback 在 Python 中,获取异常信息 traceback 主要依赖于 `traceback` 模块和 `sys.exc_info()` 方法。通过这些工具,可以捕获异常的详细传播路径,并将其输出到控制台或日志文件中,以便调试和记录。 #### 使用 `traceback.print_exc()` `traceback.print_exc()` 是一种常用的方法,用于将异常的 traceback 信息打印到标准输出或指定的文件中。它通常在 `except` 块中使用。 ```python import traceback def func(num1, num2): x = num1 * num2 y = num1 / num2 return x, y try: func(1, 0) except: # 输出异常 traceback 到控制台 traceback.print_exc() # 输出异常 traceback 到日志文件 traceback.print_exc(file=open('log.txt', 'a')) traceback.print_exc(file=open('error.txt', 'w+', encoding='utf-8')) ``` #### 使用 `sys.exc_info()` `sys.exc_info()` 返回当前正在处理的异常信息,包括异常类型、异常值和 traceback 对象。通过解包这些信息,可以更精细地控制如何处理异常。 ```python import sys import traceback try: 1 / 0 except Exception: error_type, error_value, tb = sys.exc_info() # 输出 traceback 信息 traceback.print_tb(tb) ``` #### 获取异常类型和消息 除了 traceback 信息外,还可以直接从异常对象中提取异常类型和消息。这可以通过 `Exception as e` 或 `sys.exc_info()` 来实现。 ```python try: result = 1 / 0 except Exception as e: error_type = type(e).__name__ error_message = str(e) print(f"Error Type: {error_type}, Error Message: {error_message}") ``` ```python import sys try: result = int("not a number") except Exception: error_type, error_value, traceback_info = sys.exc_info() print(f"Error Type: {error_type.__name__}, Error Message: {error_value}") ``` #### 将异常信息写入日志文件 在实际开发中,通常需要将异常信息写入日志文件以便后续分析。可以结合 `traceback.print_exc()` 和文件对象实现。 ```python import traceback try: 1 / 0 except: with open('error_log.txt', 'a', encoding='utf-8') as f: traceback.print_exc(file=f) ``` #### 精确捕获特定异常类型 为了更好地处理异常,可以使用多个 `except` 块来捕获不同类型的异常,并分别处理。 ```python try: print(x) except NameError: print('Exception Type: NameError') except Exception as e: print(f'Other Exception: {str(e)}') ``` --- ### 相关问题 1. 如何将 Python异常信息写入日志文件? 2. Python 中 `sys.exc_info()` 的作用是什么? 3. 如何在 Python 中精确捕获特定类型的异常? 4. `traceback.print_exc()` 和 `traceback.format_exc()` 有什么区别? 5. 如何在 Python获取异常的详细堆栈信息
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值