我正在使用Python的日志記錄模塊,并且想在一段時(shí)間內(nèi)禁用控制臺(tái)日志記錄,但是它不起作用。#!/usr/bin/pythonimport logginglogger = logging.getLogger() # this gets the root logger# ... here I add my own handlers #logger.removeHandler(sys.stdout)#logger.removeHandler(sys.stderr)print logger.handlers # this will print [<logging.StreamHandler instance at ...>]# but I may have other handlers there that I want to keeplogger.debug("bla bla")上面的代碼顯示了bla blaon stdout,我不知道如何安全地禁用控制臺(tái)處理程序。如何確定我暫時(shí)刪除了控制臺(tái)StreamHandler而不是另一個(gè)?
3 回答

絕地?zé)o雙
TA貢獻(xiàn)1946條經(jīng)驗(yàn) 獲得超4個(gè)贊
我找到了一個(gè)解決方案:
logger = logging.getLogger('my-logger')
logger.propagate = False
# now if you use logger it will not log to console.
這將防止日志記錄發(fā)送到包括控制臺(tái)日志記錄的上層記錄器。

鴻蒙傳說
TA貢獻(xiàn)1865條經(jīng)驗(yàn) 獲得超7個(gè)贊
我用:
logger = logging.getLogger()
logger.disabled = True
... whatever you want ...
logger.disabled = False
添加回答
舉報(bào)
0/150
提交
取消