如何用loguru打印变量值及错误堆栈信息?

如何用loguru打印变量值及错误堆栈信息?

利用loguru打印变量值及错误堆栈信息

Python的loguru日志库提供强大的功能,可以便捷地打印变量值以及错误堆栈信息,这在调试过程中非常实用,而Python自带的traceback模块则无法实现此功能。

loguru巧妙地利用了sys._getframe()函数来访问当前函数的上下文信息,包括变量值。通过操作堆栈帧,它可以获取变量的值,并在打印错误堆栈的同时输出这些变量。

以下示例代码演示了如何在loguru中使用sys._getframe()函数:

import sysimport logurulog = loguru.loggerdef get_trace_info():    print(sys._getframe().f_code.co_filename)  # 当前文件名 (也可使用__file__)    print(sys._getframe(0).f_code.co_name)  # 当前函数名    print(sys._getframe(1).f_code.co_name)  # 调用函数的函数名 (若无调用则为)    print(sys._getframe(0).f_lineno)  # 当前函数的行号    print(sys._getframe(1).f_lineno)  # 调用函数的行号try:    a = 1    b = 2    c = a / 0except ZeroDivisionError as err:    log.exception(err) # 使用exception记录异常,包含堆栈信息和上下文

运行这段代码后,输出的错误信息将包含变量abc的值:

[2023-10-27 10:30:00] ERROR: division by zeroTraceback (most recent call last):  File "", line 13, in   File "", line 8, in get_trace_infoZeroDivisionError: division by zeroDuring handling of the above exception, the following occurred:...  # 更多堆栈信息...in get_trace_info() at :8a = 1b = 2c = a / 0

如上所示,loguru 通过sys._getframe()函数成功打印了变量的值,即使这些变量是在异常发生时才被赋值的。 注意,我们使用了log.exception()而不是log.error(),因为exception会自动包含完整的异常信息和堆栈跟踪。

以上就是如何用loguru打印变量值及错误堆栈信息?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1356620.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 19:58:42
下一篇 2025年12月10日 04:49:17

相关推荐

  • AutoSAR CP自动化开发:Python如何提升效率和准确性?

    Python在AutoSAR CP自动化开发中的应用 AutoSAR CP(Classic Platform)是汽车电子控制单元(ECU)开发的核心,其高效准确的开发至关重要。 Python凭借其强大的脚本能力和丰富的库,成为AutoSAR CP自动化开发的理想工具。 Python在AutoSAR …

    2025年12月13日
    000
  • Flask中如何保存渲染后的模板页面到服务器?

    Flask应用:服务器端保存渲染后的模板页面 为了方便多机测试并查看测试结果,本文介绍如何在Flask应用中将渲染后的模板页面保存到服务器。 步骤一:安装必要的库 首先,需要安装html5lib和beautifulsoup4库: pip install html5lib beautifulsoup4…

    2025年12月13日
    000
  • Python程序CPU占用率飙升至100%:如何快速排查及解决?

    Python程序CPU占用率飙升至100%:快速诊断与修复 当你的Python程序CPU占用率突然飙升至100%,如何快速找到问题根源并解决呢?本文提供几种有效的排查方法。 一、利器:火焰图 火焰图以直观的方式展现程序的CPU消耗情况。对于Python 2程序,你可以使用flame库: 立即学习“P…

    2025年12月13日
    000
  • Python路径分析:如何使用NetworkX库查找最短路径?

    Python路径分析:利用NetworkX库高效查找最短路径 本文将指导您如何使用Python的NetworkX库进行路径分析,并高效查找图中任意两点之间的最短路径。 1. 安装NetworkX库 首先,确保已安装NetworkX库。可以使用pip命令进行安装: 立即学习“Python免费学习笔记(…

    2025年12月13日
    000
  • Python的pack()和unpack()函数:如何高效解析二进制数据?

    python 的 struct 模块:高效处理二进制数据 本文介绍 Python 的 struct 模块中 pack() 和 unpack() 函数,它们是高效解析和创建二进制数据的利器。 pack() 函数:打包数据 pack() 函数将多个 Python 值打包成一个字节字符串。其语法如下: 立…

    2025年12月13日
    000
  • Ubuntu 20.04下PyPy3如何安装pip?

    Ubuntu 20.04系统下PyPy3的pip安装指南 通过sudo apt install pypy3命令安装PyPy3后,您可能会发现无法像安装CPython的pip那样直接使用sudo apt install pypy3-pip进行安装。这是因为PyPy3默认不包含pip。 解决方法是手动安…

    2025年12月13日
    000
  • Python pywin32操作PPT时如何解决复制粘贴幻灯片导致程序崩溃的问题?

    使用pywin32操作PPT时,复制粘贴幻灯片导致程序崩溃的解决方法 在使用Python的pywin32库通过COM接口操作PowerPoint时,频繁复制粘贴幻灯片可能会导致程序崩溃。这是由于资源过度使用或COM对象管理不当造成的。 问题描述: 以下代码片段展示了初始问题:程序在复制粘贴一定数量的…

    2025年12月13日
    000
  • Jupyterhub嵌入后,为何文件操作都在服务器上生成而不是本地?

    JupyterHub嵌入后,文件操作为何在服务器而非本地生成? 您已将JupyterHub嵌入网站,但生成的文件夹和文件却存储在服务器端,而非本地。本文将解释其原因并提供解决方案。 服务器端文件生成的根本原因 JupyterHub运行于服务器环境。服务器端具备运行Python代码所需的完整环境和资源…

    2025年12月13日
    000
  • Python的yield关键字实现的是真正的协程吗?

    深入理解协程: 协程是一种轻量级的并发编程模型,允许函数暂停执行并在稍后从断点继续。真正的协程具备以下特性: 灵活的暂停与恢复: 能够在任意点暂停,并在之后从该点恢复执行。协作式调度: 协程的执行并非由操作系统调度,而是由协程自身控制,主动让出执行权。高效的上下文切换: 相较于线程,协程的上下文切换…

    2025年12月13日
    000
  • 如何完整保留目录结构地移动文件夹?

    完整保留目录结构移动文件夹的技巧 问题:如何将文件夹及其所有子文件夹和文件移动到另一个位置,同时完整保留其原始目录结构? 解答: 许多方法声称可以移动文件夹并保留其结构,但实际操作中常常达不到预期效果。 这里提供一个可靠的解决方案: 利用Python的shutil.copytree()函数,可以递归…

    2025年12月13日
    000
  • 客户端连接可用性判断:如何确定TCP连接是否已四次挥手?

    如何判断客户端TCP连接是否已断开? 在客户端-服务器架构中,服务器通常设置超时机制,在客户端长时间无活动后主动关闭连接。为了保证客户端连接可用性,开发者通常采用以下方法: 心跳机制: 定期发送心跳包,保持连接活跃,避免服务器超时关闭连接。异常处理: 直接使用连接,并在发生连接错误时进行异常捕获和重…

    2025年12月13日
    000
  • Python线程中可以创建进程吗?

    Python线程能否启动新进程? 在子线程中使用协程的场景下,很多人会疑问:为什么协程可以运行在子线程中?答案很简单: 没有任何限制! 协程是用户态的程序概念,与操作系统内核无关。它与编程语言中的if、else、while循环等语句在本质上没有区别。因此,在子线程中创建进程与在主线程中创建进程没有任…

    2025年12月13日
    000
  • Python如何移动文件夹及其所有子文件夹和文件,同时保持原有目录结构?

    python高效移动文件夹及内容,完整保留目录结构 如何在Python中移动一个文件夹,包括其所有子文件夹和文件,同时精确复制其原始目录结构? shutil.move() 函数似乎无法满足这一需求,因为它无法保留子目录。 解决方案 以下代码利用 os.walk() 遍历源文件夹,并使用 shutil…

    2025年12月13日
    000
  • 网站嵌入Jupyterhub后,如何在本地执行操作?

    网站集成JupyterHub后,如何在本地执行操作? 将JupyterHub嵌入网站后,您可能会发现操作(例如创建文件或文件夹)的结果保存在服务器端。这是因为JupyterHub在服务器上运行,依赖于服务器特定的环境才能执行操作,例如运行Python脚本需要服务器端的Python环境。 因此,直接在…

    2025年12月13日
    000
  • Python协程中能创建线程或进程吗?

    Python协程:线程与进程的兼容性 Python协程的运行机制引发了关于在协程中创建线程或进程的疑问。 一些开发者误认为协程由于自身运行于线程环境,因此无法创建新的线程。 然而,这种说法并不准确。 协程本质上是一种轻量级的并发机制,它并非操作系统层面的概念,而是一种编程语言层面的抽象。 它与if、…

    2025年12月13日
    000
  • Django 的 startproject 和 startapp 命令是如何生成代码的?

    Django 项目和应用创建:代码生成背后的秘密 Django 的 startproject 和 startapp 命令是如何在幕后生成代码的呢?答案在于其巧妙地利用模板文件。虽然你不会在源码中直接找到生成代码的函数,但其运作机制清晰可见。 首先,Django 解析命令行参数,从而调用相应的脚本文件…

    2025年12月13日
    000
  • Python命令行交互式TUI如何实现?

    构建Python命令行交互式TUI 本文介绍如何使用Python创建命令行交互式文本用户界面(TUI)。 这需要借助专门的Python库。 常用库 以下列出了常用的Python TUI库: 立即学习“Python免费学习笔记(深入)”; curses: 一个底层库,用于直接操作终端,读取用户输入和控…

    2025年12月13日
    000
  • Python安装失败且缺少scripts文件夹怎么办?

    Python安装失败:scripts文件夹缺失的解决方案 Python安装过程中,如果遇到安装失败且缺少“scripts”文件夹的情况,请尝试以下方法解决。 问题根源分析 “scripts”文件夹包含Python的命令行工具,其缺失将导致无法从命令行运行Python程序。 安装失败的原因可能包括: …

    2025年12月13日
    000
  • 如何优雅地简化Python库导入?

    高效管理Python库导入的技巧 在Python项目中,频繁导入众多常用库(例如pandas、os、re等)会使代码显得冗长且重复。本文介绍一种简洁方法,有效解决这一问题。 利用__init__.py文件集中导入 在项目根目录下创建名为__init__.py的初始化文件。在这个文件中,一次性导入所有…

    2025年12月13日
    000
  • Socket可读可写事件判定:如何理解缓冲区和触发模式?

    Socket可读可写事件的判定机制 理解Socket的可读可写事件,关键在于理解操作系统的Socket缓冲区机制。每个Socket都拥有两个缓冲区:接收缓冲区(read buffer)和发送缓冲区(write buffer)。 可读事件触发条件 Socket的可读事件表示接收缓冲区中存在可读取的数据…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信