打印全局错误信息到log里

本文介绍了如何在Python中使用sys.excepthook实现全局异常处理,通过log_exception函数将未捕获的异常信息记录到日志文件中,分别在主进程和子进程中设置自定义的日志配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

sys.excepthook 是 Python 中的一个全局异常处理钩子(hook),它允许你在发生未捕获的异常时执行自定义的处理逻辑。你可以使用 sys.excepthook 将异常信息写入日志文件。

下面是一个示例,演示如何使用 sys.excepthook 将全局异常信息写入日志文件:

import sys
import logging

def log_exception(exc_type, exc_value, exc_traceback):
    logging.error("Uncaught exception", exc_info=(exc_type, exc_value, exc_traceback))

# 设置日志配置
logging.basicConfig(filename='error.log', level=logging.ERROR)

# 将 log_exception 函数设置为全局异常处理钩子
sys.excepthook = log_exception

# 主进程逻辑代码
def main():
    # 子进程逻辑代码
    def child_process():
        # 设置日志配置
        logging.basicConfig(filename='child_error.log', level=logging.ERROR)
        # 将 log_exception 函数设置为全局异常处理钩子
        sys.excepthook = log_exception

        # 子进程逻辑代码

    child_process()

if __name__ == "__main__":
    main()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值