Python 捕捉traceback异常栈信息

简介: Python 捕捉traceback异常栈信息

捕捉traceback异常栈信息

 


相关函数简介

sys.exc_info()

返回包含3个元素(type, value, traceback)的元组,提供关于当前正被处理的异常信息。如果异常没有被处理,返回包含3None值的元组。

 

type:存放异常类型(类对象);

 

Value:获取异常参数(关联的值,或者需要抛出的第二个参数--总是异常类型是个类对象,那该参数总是一个异常类实例)its associated value or the second argument to raise, which is always a class instance if the exception type is a class object)

 

traceback:获取traceback对象,记录异常发生点(根源)

 

注意:把traceback值赋值给正在处理当前异常的函数中的本地变量,会引发循环引用问题,会影响垃圾回收。用完后需要删除。

参考连接:

https://docs.python.org/2/library/sys.html#sys.exc_info

 

traceback.extract_stack()

stack frame提取原始的traceback

 

参考连接:

https://hg.python.org/cpython/file/8dffb76faacc/Lib/traceback.py#l280

 

代码演示

#!/usr/bin/env python

# -*- coding:utf-8 -*-

 

__author__ = 'shouke'

 

import  sys

import traceback

 

def testfn():

# 定义异常信息模版

traceback_template = '''Traceback (most recent call last):

        File "%(filename)s", line %(lineno)s, in %(name)s

    %(type)s: %(message)s\n'''

 

try:

var = 5

assert var >0, 'var is larger than zero'

assert var % 2 == 0, 'var is not an even number'

except AssertionError:

       exc_type, exc_value, exc_traceback = sys.exc_info()

 

print('异常类型:', exc_type)

print('关联的值,或者需要raise的第二个参数:', exc_value)

print('异常发生点(根源)', exc_traceback)

 

 

print('--------------------------')

       traceback_details = {

'filename': exc_traceback.tb_frame.f_code.co_filename, #文件名

'lineno' : exc_traceback.tb_lineno, # 发生异常的行数

'name'  : exc_traceback.tb_frame.f_code.co_name, # 所在函数

'type'  : exc_type.__name__, # 异常类型

'message' : exc_value

       }

 

       traceback_info = traceback_template % traceback_details

print(traceback_info)

 

print('--------------------------')

       raw_traceback = traceback.extract_stack()

print(raw_traceback)

 

finally: # 为避免垃圾回收问题需要删除

del (exc_type, exc_value, exc_traceback)

 

testfn()

 

运行结果

"D:\Program Files\python33\python.exe" E:/Projects/interface_project_for_dev/teststudy.py

异常类型:

关联的值,或者需要raise的第二个参数: var is not an even number

异常发生点(根源)

--------------------------

Traceback (most recent call last):

    File "E:/Projects/interface_project_for_dev/teststudy.py", line 17, in testfn

    AssertionError: var is not an even number

 

--------------------------

[('E:/Projects/interface_project_for_dev/teststudy.py', 44, '', 'testfn()'), ('E:/Projects/interface_project_for_dev/teststudy.py', 39, 'testfn', 'raw_traceback = traceback.extract_stack()')]

 

Process finished with exit code 0

目录
相关文章
|
3月前
|
Python
Python编程获取当前日期的所属周日期信息
Python编程获取当前日期的所属周日期信息
67 1
|
10天前
|
JavaScript API C#
【Azure Developer】Python代码调用Graph API将外部用户添加到组,结果无效,也无错误信息
根据Graph API文档,在单个请求中将多个成员添加到组时,Python代码示例中的`members@odata.bind`被错误写为`members@odata_bind`,导致用户未成功添加。
36 10
|
2月前
|
缓存 监控 Linux
Python 实时获取Linux服务器信息
Python 实时获取Linux服务器信息
|
2月前
|
测试技术 开发者 Python
对于Python中的异常要如何处理,raise关键字你真的了解吗?一篇文章带你从头了解
`raise`关键字在Python中用于显式引发异常,允许开发者在检测到错误条件时中断程序流程,并通过异常处理机制(如try-except块)接管控制。`raise`后可跟异常类型、异常对象及错误信息,适用于验证输入、处理错误、自定义异常、重新引发异常及测试等场景。例如,`raise ValueError("Invalid input")`用于验证输入数据,若不符合预期则引发异常,确保数据准确并提供清晰错误信息。此外,通过自定义异常类,可以针对特定错误情况提供更具体的信息,增强代码的健壮性和可维护性。
|
2月前
|
Python
在Python中,`try...except`语句用于捕获和处理程序运行时的异常
在Python中,`try...except`语句用于捕获和处理程序运行时的异常
65 5
|
2月前
|
Python
在Python中,自定义函数可以抛出自定义异常
在Python中,自定义函数可以抛出自定义异常
57 5
|
2月前
|
存储 开发者 Python
自定义Python的异常
自定义Python的异常
25 5
|
3月前
|
存储 索引 Python
|
2月前
|
存储 数据采集 数据库
用 Python 爬取淘宝商品价格信息时需要注意什么?
使用 Python 爬取淘宝商品价格信息时,需注意法律和道德规范,遵守法律法规和平台规定,避免非法用途。技术上,可选择 Selenium 和 Requests 库,处理反爬措施如 IP 限制、验证码识别和请求频率控制。解析页面数据时,确定数据位置并清洗格式。数据存储可选择 CSV、Excel、JSON 或数据库,定期更新并去重。还需进行错误处理和日志记录,确保爬虫稳定运行。
|
2月前
|
数据采集 Web App开发 iOS开发
如何利用 Python 的爬虫技术获取淘宝天猫商品的价格信息?
本文介绍了使用 Python 爬虫技术获取淘宝天猫商品价格信息的两种方法。方法一使用 Selenium 模拟浏览器操作,通过定位页面元素获取价格;方法二使用 Requests 和正则表达式直接请求页面内容并提取价格。每种方法都有详细步骤和代码示例,但需注意反爬措施和法律法规。