- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
例如,我有一些脚本 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/
我最近购买了《C 编程语言》并尝试了 Ex 1-8这是代码 #include #include #include /* * */ int main() { int nl,nt,nb;
早上好!我有一个变量“var”,可能为 0。我检查该变量是否为空,如果不是,我将该变量保存在 php session 中,然后调用另一个页面。在这个新页面中,我检查我创建的 session 是否为空,
我正在努力完成 Learn Python the Hard Way ex.25,但我无法理解某些事情。这是脚本: def break_words(stuff): """this functio
我是一名优秀的程序员,十分优秀!