我们在一个 python 程序/库上工作,我们想为其设置一个日志系统。基本上,我们想在终端上或文件上登录。为此,我们将使用标准发行版中嵌入的优秀日志记录包。
日志级别应该由用户通过其首选项进行自定义。我的问题是如何检索连接到记录器的处理程序之一?我在想有点像这样的事情:
import logging
class NullHandler(logging.Handler):
def emit(self,record):
pass
HANDLERS = {}
HANDLERS['console'] = logging.StreamHandler()
HANDLERS['logfile'] = logging.FileHandler('test.log','w')
logging.getLogger().addHandler(NullHandler())
logging.getLogger('console').addHandler(HANDLERS['console'])
logging.getLogger('logfile').addHandler(HANDLERS['logfile'])
def set_log_level(handler, level):
if hanlder not in HANDLERS:
return
HANDLERS[handler].setLevel(level)
def log(message, level, logger=None):
if logger is None:
logger= HANDLERS.keys()
for l in logger:
logging.getLogger(l).log(level, message)
如您所见,我的实现意味着使用 HANDLERS 全局字典来存储我创建的处理程序的实例。我找不到更好的方法来做到这一点。在那个设计中,可以说因为我只是为每个记录器插入一个处理程序,我的记录器对象的处理程序属性应该没问题,但我正在寻找更通用的东西(即如果有一天一个多个处理程序被插入怎么办到我的一个记录器?)
你怎么看待这件事 ?
非常感谢您
埃里克