我有以下日志记录类,当在代码中指定为格式化程序时,它可以正常工作。它通过在要记录的消息的开头添加一个字符串来扩展现有的格式化程序,以帮助显示消息的重要性。 (我不只是使用%(levelname)s
在格式字符串中,因为我不想显示 DEBUG 或 INFO 前缀。)
class PrependErrorLevelFormatter(logging.Formatter):
def __init__(self, default):
self._default_formatter = default
def format(self, record):
if record.levelno == logging.WARNING:
record.msg = "[WARNING] " + record.msg
elif record.levelno == logging.ERROR:
record.msg = "[ERROR] " + record.msg
elif record.levelno == logging.CRITICAL:
record.msg = "[CRITICAL] " + record.msg
return self._default_formatter.format(record)
现在我希望能够通过logging.config.fileConfig()加载的配置文件来分配它。我尝试过这样的语法:
[formatter_PrependErrorLevelFormatter]
format=%(asctime)s %(message)s
datefmt=%X
class=PrependErrorLevelFormatter
不幸的是,我在解析此类时遇到错误:
File "C:\Python27\lib\logging\config.py", line 70, in fileConfig
formatters = _create_formatters(cp)
File "C:\Python27\lib\logging\config.py", line 127, in _create_formatters
c = _resolve(class_name)
File "C:\Python27\lib\logging\config.py", line 88, in _resolve
found = __import__(used)
ImportError: No module named PrependErrorLevelFormatter
我尝试在类名前加上它所在模块的名称作为前缀,但得到相同的错误。即使它可以解析该类,由于我需要提供额外的默认格式化程序参数,它也可能无法工作。
如何使用logging.config系统达到我想要的结果?