繁体   English   中英

Python记录了可重用模块的最佳实践,这些模块旨在包含在其他代码中

[英]Python logging best practice for reusable modules intended to be included with other code

我正在开发一个可重用的Python模块(如果重要的话,用于Python 2.7)。 我想知道对于希望将我的模块包含在具有自己的日志记录方法的更大框架中的其他人来说,最佳实践是什么。

是否有标准方法在我的模块中设置日志记录以使用外部调用程序定义的任何记录器?

这是一篇很棒的博客文章,概述了一些我尝试采用的最佳实践: http//eric.themoritzfamily.com/learning-python-logging.html

他详细介绍了所有细节和理由,但基本上归结为几个简单的原则。

  1. 根据模块的__name__使用getLogger并开始记录:

      import logging logger = logging.getLogger(__name__) logger.info( ... ) logger.debug( ... ) 
  2. 不要在模块中定义处理程序或配置适当的日志级别,因为它们可能会干扰您所考虑的“外部调用程序”。 您(或您的用户)可以根据需要在主应用程序代码中为所有子模块设置处理程序和所需的日志记录详细信息级别。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM