3

我有一个从文件配置的记录器,并且想更改我的日志记录级别,而不必更改 .conf 文件,而是使用内联代码;

import logging.config

logging.config.fileConfig('..\\LoggingConfig\\loggingfile.conf')

logging.StreamHandler.setLevel(logging.info)

logging.debug("Debug")
logging.info("Info")

这应该只将“信息”日志行打印到屏幕上。我不知道在哪个对象上调用 setLevel()!logging.StreamHandler.setLevel(logging.info) 只是在 30 分钟搜索后在黑暗中刺伤......

loggingfile.conf 文件;

[loggers]
keys=root

[logger_root]
handlers=screen
level=NOTSET

[formatter_modfunc]
format=%(module)-20s  %(funcName)-25s %(levelno)-3s: %(message)s

[handlers]
keys=screen

[handler_screen]
class=StreamHandler
formatter=modfunc
level=DEBUG
args=(sys.stdout,)
qualname=screen
4

2 回答 2

7

您需要调用setLevel您的Logger实例。

LOGGER = logging.getLogger('your.module.file.name')
LOGGER.setLevel(_level)
LOGGER.info('foo')

如果你只使用基本的记录器,你可以这样做

logging.basicConfig(level=_level)
logging.info('foo')

请参阅http://docs.python.org/howto/logging.html

于 2012-04-14T07:05:55.347 回答
6

当使用 logging.config.fileConfig 并且您想一次动态更改所有子记录器的级别时,您可以...

a)为根记录器设置级别

logging.getLogger().setLevel(logging.WARNING)

b)禁用其他级别

logging.disable(logging.INFO)
于 2012-06-21T08:00:12.380 回答