尽管已正确设置,但Python记录器不会打印调试消息

Art*_*hur 5 python logging contextmanager python-3.x

我有以下代码,我只想 使用contextmanager来使用日志记录模块.

from contextlib import contextmanager
import logging

@contextmanager
def log_level(level, name):
    logger = logging.getLogger(name)
    old_level = logger.getEffectiveLevel()
    print('log_level.old_level: ' + str(old_level))
    logger.setLevel(level)
    print('log_level.new_level: ' + str(logger.getEffectiveLevel()))
    try:
        yield logger
    finally:
        logger.setLevel(old_level)

if __name__ == '__main__':

    with log_level(logging.DEBUG, 'my-log') as logger:
        print('__main__.log_level.logger.level: ' + str(logger.getEffectiveLevel()))
        logger.debug('Debug with logger: will print')
        logger.warning('Warning')
        print('__main__.log_level.logger.level: ' + str(logger.getEffectiveLevel()))
    print('__main__.logger.level: ' + str(logger.getEffectiveLevel()))
Run Code Online (Sandbox Code Playgroud)

可以看出,在main.log_level中,记录器级别应该是DEBUG,它应该打印消息'Debug with logger:will print'.但是,当我运行代码时,此调试消息不会打印.查看代码的打印件,它表示记录器在log_level内部具有DEBUG级别,并且当它退出log_level时级别返回到WARNING.这是我的输出,当使用python 3执行时:

log_level.old_level: 30
log_level.new_level: 10
__main__.log_level.logger.level: 10
Warning
__main__.log_level.logger.level: 10
__main__.logger.level: 30
Run Code Online (Sandbox Code Playgroud)

我想帮助理解为什么logger.debug('使用logger调试:将打印')不打印.

Vin*_*jip 13

您尚未将任何处理程序附加到记录器.因此,使用内部"最后手段处理程序",它只输出级别WARNING及以上的事件.请参阅文档的这一部分,了解如果未提供处理程序配置会发生什么.如果您logging.basicConfig()with声明之前致电,DEBUG则应显示消息.

请注意,文档还包含使用带有日志记录的上下文管理器的工作示例.