【Python系列】Python中打印详细堆栈信息的技巧

embedded/2024/11/18 18:01:55/

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
img

  • 推荐:kwan 的首页,持续学习,不断总结,共同进步,活到老学到老
  • 导航
    • 檀越剑指大厂系列:全面总结 java 核心技术,jvm,并发编程 redis,kafka,Spring,微服务等
    • 常用开发工具系列:常用的开发工具,IDEA,Mac,Alfred,Git,typora 等
    • 数据库系列:详细总结了常用数据库 mysql 技术点,以及工作中遇到的 mysql 问题等
    • 新空间代码工作室:提供各种软件服务,承接各种毕业设计,毕业论文等
    • 懒人运维系列:总结好用的命令,解放双手不香吗?能用一个命令完成绝不用两个操作
    • 数据结构与算法系列:总结数据结构和算法,不同类型针对性训练,提升编程思维,剑指大厂

非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨

博客目录

    • 一. 使用`traceback`模块
      • 1.1 `traceback.print_exc()`
      • 1.2 `traceback.format_exc()`
    • 二. 在异常处理中打印堆栈
      • 2.1 基本用法
      • 2.2 定制输出
    • 三. 使用`logging`模块
      • 3.1 配置日志
      • 3.2 记录堆栈信息
    • 四. 堆栈信息的高级应用
      • 4.1 集成调试器
      • 4.2 性能分析
      • 4.3 代码覆盖率

在 Python 开发过程中,调试是一个不可或缺的环节。当代码出现问题时,能够快速准确地定位问题所在是提高开发效率的关键。堆栈信息作为程序执行过程中的调用记录,对于理解程序的运行状态和定位错误至关重要。

一. 使用traceback模块

traceback模块是 Python 标准库中专门用于处理异常堆栈跟踪的工具。它提供了丰富的函数来获取、格式化和打印异常信息。

1.1 traceback.print_exc()

当程序抛出异常时,traceback.print_exc()函数可以直接打印异常信息和堆栈跟踪,无需手动处理异常对象。这种方式简单快捷,适用于快速定位问题。

python">import tracebacktry:# 你的代码逻辑# 可能会引发异常的代码
except Exception as e:traceback.print_exc()

1.2 traceback.format_exc()

如果你需要对堆栈信息进行进一步的处理,比如记录到日志文件或者自定义输出格式,traceback.format_exc()是一个更好的选择。它返回一个包含堆栈信息的字符串,你可以将其打印出来或者用于其他目的。

python">import tracebacktry:# 你的代码逻辑
except Exception:print(traceback.format_exc())

二. 在异常处理中打印堆栈

except块中,除了直接使用traceback模块的函数外,还可以结合print函数来打印堆栈信息。这种方式更加灵活,可以根据需要定制输出内容。

2.1 基本用法

python">import tracebacktry:# 你的代码逻辑
except Exception:print(traceback.format_exc())

2.2 定制输出

你可以根据需要定制输出格式,比如添加额外的错误信息或者高亮显示某些关键部分。

python">import tracebacktry:# 你的代码逻辑
except Exception:exc_type, exc_value, exc_traceback = sys.exc_info()print(f"Error: {exc_type.__name__}, Message: {exc_value}")print(traceback.format_exc())

三. 使用logging模块

对于大型项目或者需要将错误信息记录到日志文件的场景,logging模块提供了更加强大的日志管理功能。

3.1 配置日志

首先,需要配置日志系统,包括日志级别、日志文件名等。

python">import logging
import tracebacklogging.basicConfig(level=logging.DEBUG, filename='app.log')

3.2 记录堆栈信息

在异常处理中,使用logger.exception()来记录堆栈信息。这个方法会自动记录异常的堆栈跟踪,无需手动格式化。

python">import logging
import tracebacktry:# 你的代码逻辑
except Exception:logging.exception("An unexpected error occurred")

四. 堆栈信息的高级应用

除了基本的堆栈信息打印,还可以结合其他工具和技术来提高错误追踪的效率。

4.1 集成调试器

在某些情况下,直接打印堆栈信息可能不足以解决问题。这时,可以考虑集成调试器,如pdb,来逐步执行代码,观察变量状态。

python">import pdb; pdb.set_trace()

4.2 性能分析

对于性能问题,除了堆栈信息外,还需要分析代码的执行时间。可以使用cProfile模块来进行性能分析。

python">import cProfiledef my_function():# 你的代码逻辑passcProfile.run('my_function()')

4.3 代码覆盖率

在这里插入图片描述

在测试过程中,了解代码的覆盖率也很重要。可以使用coverage模块来分析测试覆盖率,确保所有代码路径都被测试到。

coverage run -m unittest discover
coverage report -m

觉得有用的话点个赞 👍🏻 呗。
❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄

💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍

🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

img


http://www.ppmy.cn/embedded/138601.html

相关文章

elementUI input 禁止内容两端存在空格,或者是自动去除两端空格

需求 项目中有需求&#xff1a;输入框中禁止内容两端存在空格&#xff0c;或者是自动去除两端空格。 解决方法 vue的api文档中有过介绍&#xff0c;使用.trim可以去掉用户输入内容中两端的空格&#xff0c;如下图 代码 <el-input v-model.trim"name" cleara…

Rust:原子操作 AtomicBool

在 Rust 中&#xff0c;你可以使用 std::sync::atomic 模块来进行原子操作。原子操作在多线程环境中特别有用&#xff0c;因为它们可以确保操作的原子性和可见性&#xff0c;从而避免数据竞争和其他并发问题。 为了读取和设置布尔值&#xff0c;你可以使用 AtomicBool 类型。以…

8. 基于 Redis 实现限流

在高并发的分布式系统中&#xff0c;限流是保证服务稳定性的重要手段之一。通过限流机制&#xff0c;可以控制系统处理请求的频率&#xff0c;避免因瞬时流量过大导致系统崩溃。Redis 是一种高效的缓存数据库&#xff0c;具备丰富的数据结构和原子操作&#xff0c;适合用来实现…

统计HBase表记录条数的方法

一、hbase-shell的count命令 这是最简单直接的操作&#xff0c;但是执行效率非常低&#xff0c;适用于百万级以下的小表RowCount统计&#xff01; hbase> count ns1:t1 hbase> count t1 hbase> count t1, INTERVAL > 100000 二、利用hbase.RowCounter包执行MR…

后仿真中的GLS测试用例的选取规则

一 仿真目的 门级仿真的主要目的,从根本上来说,是确保在物理实现阶段所应用的SDC(Standard Delay Constraint,标准延迟约束文件)中的各项约束条件准确无误地反映了设计的初衷和要求。这一环节在芯片设计的整体流程中占据着至关重要的地位,因为它直接关系到最终芯片的物理…

Visual Studio 2022 安装

下载链接 https://visualstudio.microsoft.com/zh-hans/thank-you-downloading-visual-studio/?skuCommunity&channelRelease&versionVS2022&sourceVSLandingPage&cid2030&passivefalse 安装 以c为例&#xff0c;列出需要勾选的项目&#xff0c;有3个&a…

请介绍一下Python的网络编程以及如何使用socket模块进行网络通信

1、请介绍一下Python的网络编程以及如何使用socket模块进行网络通信。 Python中的网络编程主要是通过socket模块实现的。Socket模块提供了基本的套接字接口&#xff0c;使得Python程序可以连接到网络上的其他设备或服务。下面是对Python网络编程和socket模块的基本介绍以及如何…

Istio分布式链路监控搭建:Jaeger与Zipkin

分布式追踪定义 分布式追踪是一种用来跟踪分布式系统中请求的方法&#xff0c;它可以帮助用户更好地理解、控制和优化分布式系统。分布式追踪中用到了两个概念&#xff1a;TraceID 和 SpanID。 TraceID 是一个全局唯一的 ID&#xff0c;用来标识一个请求的追踪信息。一个请求…