你好,我是征哥,写 Python 的你可能会遇到这种情况,你知道程序报错了,因为这个异常没有被捕捉,也不知道哪行代码出错了,只能手工运行一下看看哪里错了,但是,这个异常很难再次复现。
要是在日志中记录了这个异常的 traceback 信息就好了。
本文就分享一下两个方法,记录异常的 traceback 信息。
方法一:使用 logger.exception
logger.exception 方法可以将异常的 traceback 信息记录到日志里,这里有一个小小的例子:
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 也是可以的:
logger = logging.getLogger()
try:
do_something()
except Exception as e:
logger.exception("some message")
方法二:使用标准库 traceback
导入标准库 traceback 后,我们还可以这样来记录异常的详细信息:
import traceback
# 此处代码和方法一一样
if __name__ == "__main__":
try:
main()
except Exception as e:
logging.error(f"main Exception: {traceback.format_exc()}")
raise
这样,运行结果和方法一是一样的,其中 traceback.format_exc 打印的就是异常的详细信息。

最后的话
本文分享了日志记录异常的方法,如果觉得有帮助,请点赞、转发、在看。如果技术问题欢迎添加微信「somenzz」,回复「技术交流」,拉你加入纯技术交流群,一起讨论。
推荐阅读:
原文始发于微信公众号(Python七号):如何在 Python 的日志中记录异常的 traceback 信息?
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/39733.html