前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何在 Python 的日志中记录异常的 traceback 信息?

如何在 Python 的日志中记录异常的 traceback 信息?

作者头像
somenzz
发布2022-05-24 15:04:49
8100
发布2022-05-24 15:04:49
举报
文章被收录于专栏:Python七号

你好,我是征哥,写 Python 的你可能会遇到这种情况,你知道程序报错了,因为这个异常没有被捕捉,也不知道哪行代码出错了,只能手工运行一下看看哪里错了,但是,这个异常很难再次复现。

要是在日志中记录了这个异常的 traceback 信息就好了。

本文就分享一下两个方法,记录异常的 traceback 信息。

方法一:使用 logger.exception

logger.exception 方法可以将异常的 traceback 信息记录到日志里,这里有一个小小的例子:

代码语言:javascript
复制
import logging

logging.basicConfig(
    filename="./demo.log",
    level=logging.DEBUG,
    format="%(asctime)s %(levelname)s %(message)s",
    datefmt="%Y-%m-%d %H:%M:%S",
)


def func1():
    logging.info("func1 called")
    1 / 0


def func2():
    print("func2 called")


def main():
    func1()
    func2()


if __name__ == "__main__":
    try:
        main()
    except Exception as e:
        logging.exception(f"main exception: {str(e)}")
        raise

执行该代码之后,你会在当前路径下看到 demo.log 文件,其内容如下:

这样当发生异常时,详细信息可以在日志中看到。上述代码里面用的是 logging.exception,使用 logger 也是可以的:

代码语言:javascript
复制
logger = logging.getLogger()
try:
    do_something()
except Exception as e:
    logger.exception("some message")

方法二:使用标准库 traceback

导入标准库 traceback 后,我们还可以这样来记录异常的详细信息:

代码语言:javascript
复制
import traceback

# 此处代码和方法一一样

if __name__ == "__main__":
    try:
        main()
    except Exception as e:
        logging.error(f"main Exception: {traceback.format_exc()}")
        raise

这样,运行结果和方法一是一样的,其中 traceback.format_exc 打印的就是异常的详细信息。

最后的话

本文分享了日志记录异常的方法。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-05-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Python七号 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 方法一:使用 logger.exception
  • 方法二:使用标准库 traceback
  • 最后的话
相关产品与服务
日志服务
日志服务(Cloud Log Service,CLS)是腾讯云提供的一站式日志服务平台,提供了从日志采集、日志存储到日志检索,图表分析、监控告警、日志投递等多项服务,协助用户通过日志来解决业务运维、服务监控、日志审计等场景问题。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档