gpt4 book ai didi

logging - Python 日志记录 : display only information from debug level

转载 作者:行者123 更新时间:2023-12-04 03:44:34 25 4
gpt4 key购买 nike

对于我在 Python (2.7) 中的第一个日志记录实验,我正在创建一个基本的日志记录模块,它将快速创建一个记录器(因此我不必为每个模块/类配置它)。

我想要做的是创建一个记录器,它在控制台上显示所有信息级别和更高级别的消息,并将所有调试级别信息移动到一个文本文件中。

到目前为止,我已经创建了一个记录器,它打印 INFO 并一直到控制台,并将每条日志消息打印到一个文本文件中。但是,我不希望文本文件中包含所有 INFO 和更高级别的消息。

我做了一个Python Fiddle其中包含我的代码。

我使用了教程中的以下调试消息:

log.debug('All systems operational')
log.info('Airspeed 300 knots')
log.warn('Low on fuel')
log.error('No fuel. Trying to glide.')
log.critical('Glide attempt failed. About to crash.')

控制台上的哪个产生:
[INFO] root: Airspeed 300 knots
[WARNING] root: Low on fuel
[ERROR] root: No fuel. Trying to glide.
[CRITICAL] root: Glide attempt failed. About to crash.

在我的 debug_log.txt 文件中:
2013-06-14 14:51:46,963:DEBUG:root:All systems operational
2013-06-14 14:51:46,964:INFO:root:Airspeed 300 knots
2013-06-14 14:51:46,964:WARNING:root:Low on fuel
2013-06-14 14:51:46,964:ERROR:root:No fuel. Trying to glide.
2013-06-14 14:51:46,964:CRITICAL:root:Glide attempt failed. About to crash.

在上面的 block 中,后四行不应该在文件中。我正在尝试做的事情是否可行,我将如何获得预期的结果?

最佳答案

您必须创建自己的 handler object .
来自文档:位于核心日志记录包中的 FileHandler 类将日志记录输出发送到磁盘文件。它继承了 StreamHandler 的输出功能。所以这里的想法是扩展FileHandler类,并在 emit()方法,过滤掉所有record不在 logging.DEBUG 中的对象等级。
我没有对此进行测试,但我认为它可以完成这项工作:

from logging import FileHandler, DEBUG

log = logging.getLogger('foo')


class DebugFileHandler(FileHandler):
def __init__(self, filename, mode='a', encoding=None, delay=False)
super().__init__(filename, mode, encoding, delay)

def emit(self, record):
if not record.levelno == DEBUG:
return
super().emit(record)

log.addHandler(DebugFileHandler())
当然,您必须使此代码适应您的代码。而且,老实说, record.level是一个疯狂的猜测,但我认为这是有道理的 :-) 而且, I got it right !
在此示例中,处理程序将仅应用于 foo记录器。您可能希望为您的主处理程序激活它,或者只为某些特定的处理程序激活它,您可能喜欢。

关于logging - Python 日志记录 : display only information from debug level,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17108973/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com