Иерархия журналов против корневого регистратора? - PullRequest
34 голосов
/ 11 ноября 2010

Где-то в недрах моего кода у меня есть что-то вроде:

logger = logging.getLogger('debug0.x')

Как я понимаю, это должно только отвечать, когда я ранее сделал что-то вроде:

logging.basicConfig(filename='10Nov2010a.txt',level=logging.DEBUG, name='debug0')

обратите внимание, что имя было определено как debug0 . Тем не менее, я обнаружил, что если сделать

logging.basicConfig(filename='10Nov2010a.txt',level=logging.DEBUG)

без ключевого слова name , тогда описанный выше регистратор debug0.x реагирует и записывает данные в файл журнала. Я думал, что это сработает только в первом случае, когда регистратор был назван.

Я в замешательстве.

Ответы [ 2 ]

67 голосов
/ 11 ноября 2010

Модуль Python logging организует регистраторы в иерархии.Все регистраторы являются потомками корневого регистратора.Каждый регистратор передает сообщения журнала своему родителю.

Новые регистраторы создаются с помощью функции getLogger().Вызов функции logging.getLogger('debug0.x') создает регистратор x, который является дочерним по отношению к debug0, который сам является дочерним по отношению к корневому регистратору.При входе в этот регистратор он передает сообщение своему родителю, а его родитель передает сообщение корневому регистратору.Вы настроили ведущий логгер для входа в файл с помощью функции basicConfig(), поэтому ваше сообщение будет там.

13 голосов
/ 11 ноября 2010

Если вы извлекаете код или документ:

>>> print logging.basicConfig.__doc__

    Do basic configuration for the logging system.

    This function does nothing if the root logger already has handlers
    configured. ...............
    A number of optional keyword arguments may be specified, which can alter
    the default behaviour.

    filename  Specifies that a FileHandler be created, using the specified
              filename, rather than a StreamHandler.
    filemode  Specifies the mode to open the file, if filename is specified
              (if filemode is unspecified, it defaults to 'a').
    format    Use the specified format string for the handler.
    datefmt   Use the specified date/time format.
    level     Set the root logger level to the specified level.
    stream    Use the specified stream to initialize the StreamHandler. Note
              that this argument is incompatible with 'filename' - if both
              are present, 'stream' is ignored.

logging.basicConfig вообще не использует аргумент имени.Инициализирует корневой логгер.В то время как getLogger принимает аргумент «имя»

>>> print logging.getLogger.__doc__

    Return a logger with the specified name, creating it if necessary.

    If no name is specified, return the root logger.
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...