首页 > 解决方案 > 如何对单个包使用 python 日志记录

问题描述

我正在开发一个包并在开发过程中使用日志记录来打印我的调试/信息。有没有一种好方法可以只为我的包启用日志记录而不为根目录下的所有内容启用它?

假设我有 my_package:

# Some package from elsewhere that I need but don't want to see logging from
import other_package  

import logging
from logging import NullHandler
logger = logging.getLogger(__name__)
logger.addHandler(NullHandler())

def my_func():
    logger.debug("a message")

以及使用该包的主要功能:

import my_package

# Some package from elsewhere that I need but don't want to see logging from
import another_package

import logging
logging.basicConfig(level=logging.DEBUG)

my_package.my_func()

此设置将让我看到 my_func() 对 logger.debug() 的调用,但它也会显示来自 other_package 和 another_package 的任何 logger.debug() 调用,这是我不想看到的。如何设置仅从 my_package 看到日志记录的内容?

我可以做一些骇人听闻的事情,比如硬编码禁用彼此包的 logging.propagate 或类似的东西,但感觉应该有更好的方法。

标签: pythonloggingpython-logging

解决方案


您已经为您的包定义了一个唯一的记录器。你只需要配置它。由于包记录器继承自根记录器,因此您指定的任何内容也basicConfig适用于它。您只需要在调用basicConfig.

import logging
logging.basicConfig(level=logging.WARNING)
logging.getLogger('my.package').setLevel(logging.DEBUG)

推荐阅读