知道Python日志语句存储在哪里的方法是什么?
即如果我这样做:
import logging
log = logging.getLogger(__name__)
log.info('Test')
在哪里可以找到日志文件?另外,当我打电话时:
logging.getLogger(__name__)
这与记录器的行为/保存方式有某种关系吗?
该logging
模块使用附加到记录器的处理程序来决定最终存储或显示消息的方式,位置或方式。您可以logging
默认配置为也写入文件。您应该真正阅读过文档,但是如果您将要写入消息的文件的名称调用到logging.basicConfig(filename=log_file_name)
哪里log_file_name
(请注意,您必须在logging
调用其他任何文件之前先执行此操作),然后所有消息都会记录到所有记录器中(除非稍后会进行一些进一步的重新配置)。请注意记录器设置为什么级别;如果内存可用,info
则低于默认日志级别,因此您还必须level=logging.INFO
将参数包括在内,以使basicConfig
消息最终存储在文件中。
至于问题的另一部分,则logging.getLogger(some_string)
返回一个Logger
对象,该对象从root记录器插入到层次结构中的正确位置,名称为的值some_string
。调用时不带参数,它将返回根记录器。__name__
返回当前模块的名称,因此logging.getLogger(__name__)
返回Logger
名称设置为当前模块名称的对象。这是与一起使用的常见模式logging
,因为它使记录器结构镜像您代码的模块结构,这通常使调试时记录消息更加有用。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句