我想要从主模块和所有子模块记录到单个日志文件。
从主文件(我在其中定义记录器)发送的日志消息按预期工作。但是,从对导入函数的调用中发送的参数将丢失。
如果我像下面的示例1那样使用logging.basicConfig,它就可以工作。但允许更多自定义设置的第二个示例不起作用。
你知道为什么吗?
# in the submodule I have this code
import logging
logger = logging.getLogger(__name__)
示例1-工作
在这里,我创建了两个处理程序并将它们传递给basicConfig
# definition of root looger in main module
formatter = logging.Formatter(fmt="%(asctime)s %(name)s.%(levelname)s: %(message)s", datefmt="%Y.%m.%d %H:%M:%S")
handler = logging.FileHandler('logger.log')
handler.setFormatter(formatter)
handler.setLevel(logging.DEBUG)
handler2 = logging.StreamHandler(stream=None)
handler2.setFormatter(formatter)
handler2.setLevel(logging.DEBUG)
logging.basicConfig(handlers=[handler, handler2], level=logging.DEBUG)
logger = logging.getLogger(__name__)
示例2-不工作的
在这里,我创建了两个处理程序,并将它们addHandler()
到根记录器:
# definition of root looger in main module
logger = logging.getLogger(__name__)
logger.setLevel(logging.DEBUG)
handler = logging.FileHandler('logger.log')
handler.setFormatter(formatter)
handler.setLevel(logging.DEBUG)
#handler.setLevel(logging.ERROR)
logger.addHandler(handler)
handler = logging.StreamHandler(stream=None)
handler.setFormatter(formatter)
handler.setLevel(logging.DEBUG)
logger.addHandler(handler)
发布于 2018-07-02 04:00:04
您需要在软件的主模块中配置(一个也是唯一的)根记录器。这是通过调用
logger = logging.getLogger() #without arguments
而不是
logger = logging.getLogger(__name__)
第二个示例使用脚本的名称创建一个单独的子记录器。
如果在子模块中没有定义处理程序,日志消息将向下传递到根记录器来处理它。
可以在此处找到相关问题:Python Logging - How to inherit root logger level & handler
https://stackoverflow.com/questions/51125808
复制相似问题