gpt4 book ai didi

python - 避免日志记录模块中的单例模式

转载 作者:太空宇宙 更新时间:2023-11-04 05:10:49 25 4
gpt4 key购买 nike

例如,我有一些脚本 test1.py,代码如下:

import logging
from logging.handlers import RotatingFileHandler
import some_module

handler = RotatingFileHandler('TEST1.log', maxBytes=18000, backupCount=7)
logger = logging.getLogger(__name__)
logger.addHandler(handler)
logging.getLogger("some_module").addHandler(handler)

do_something():
some_module.do_smth()

do_something()

我还有另一个脚本 test2.py,代码如下:

import logging
from logging.handlers import RotatingFileHandler
import some_module

handler = RotatingFileHandler('TEST2.log', maxBytes=18000, backupCount=7)
logger = logging.getLogger(__name__)
logger.addHandler(handler)
logging.getLogger("some_module").addHandler(handler)

do_something():
some_module.do_smth_else()

do_something()

然后我将两个脚本都导入到文件 app.py 中,由于某些原因,它可以调用其中一个脚本。

问题是,脚本 test1.py 中模块 some_module 的所有日志消息都写入了两个日志文件:TEST1.log 和 TEST2.log。

据我所知,问题出在单例模式上,因此模块日志记录类似于我所有脚本的全局模块,它们在同一进程中工作。因此,当我将 test1.py 导入 app.py 时,它会第一次为 some_module 添加处理程序,然后,当我将 test2.py 导入 app.py 时,它会再次为 some_module 添加处理程序,并且该模块现在有 2 个处理程序。

有没有办法单独为这个模块添加处理程序,所以所有由 test1.py 调用的调试消息都将写入 TEST1.log,而不是 TEST2.log。

更新:

在我的例子中,我正在尝试用这个 module 来做到这一点, 似乎它不起作用:

logging.getLogger("TeleBot.test1").setLevel(logging.DEBUG)
logging.getLogger("TeleBot.test1").addHandler(handler)

我的日志文件中没有任何内容,但如果我只是简单地做:

logging.getLogger("TeleBot").setLevel(logging.DEBUG)
logging.getLogger("TeleBot").addHandler(handler)

它正在工作,但是,正如我在问题中提到的,它会将调试消息写入所有文件。那么,这是这个特定模块中的错误吗?

最佳答案

在两个文件中执行 logging.getLogger("some_module") 会返回与您已经观察到的相同的 Logger 对象。

要在每个文件中获取单独的 Logger,只需每次在 getLogger() 中提供不同的名称即可。

例如在 test1.py 中

logging.getLogger("some_module.test1").addHandler(handler)

并在 test2.py 中

logging.getLogger("some_module.test2").addHandler(handler)

关于python - 避免日志记录模块中的单例模式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43048196/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com