到目前为止,我发现的最好方法是在settings.py中初始化日志记录设置-其他地方。你可以使用配置文件,也可以按程序逐步进行配置-这仅取决于你的要求。关键是,我通常使用级别和有时记录日志的方式将我想要的处理程序添加到根记录器中。过滤器将我想要的事件获取到适当的文件,控制台,系统日志等。你当然可以将处理程序添加到任何其他记录器中同样,但是根据我的经验,通常不需要这样做。
在每个模块中,我使用
logger = logging.getLogger(__name__)
并将其用于记录模块中的事件(并且,如果我想进一步区分),请使用记录器,该记录器是上面创建的记录器的子级。
如果我的应用程序可能会在未配置settings.py中配置日志记录的站点中使用,请在以下位置定义NullHandler:
#someutils.pyclass NullHandler(logging.Handler): def emit(self, record): passnull_handler = NullHandler()
并确保将其实例添加到我的应用程序中使用日志记录的模块中创建的所有记录器中。(注意:NullHandler已经在Python 3.1的日志记录包中,并且将在Python 2.7中使用。)
logger = logging.getLogger(__name__)logger.addHandler(someutils.null_handler)
这样做是为了确保你的模块在未配置settings.py日志记录的站点中正常运行,并且不会收到任何令人讨厌的“找不到XYZ记录程序的处理程序”消息(这些警告可能会配置错误的日志记录)。
这样做可以满足你规定的要求:
- 你可以像当前一样为不同的事件设置不同的日志处理程序。
- 轻松访问模块中的记录器-使用
getLogger(__name__)
。 - 容易适用于命令行模块-它们也可以导入
settings.py
。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)