У меня есть файл конфигурации регистрации:
logger_config.yml
version: 1
formatters:
simple:
format: '%(asctime)s - %(levelname)s - %(message)s'
handlers:
console:
class: logging.StreamHandler
level: DEBUG
formatter: simple
stream: ext://sys.stdout
file:
class: logging.FileHandler
level: DEBUG
formatter: simple
filename: train.log
loggers:
trainLogger:
level: DEBUG
handlers: [console]
propagate: 1
root:
level: DEBUG
handlers: [console]
propagate: 1
И простой скрипт:
test.py
import logging
import logging.config
import yaml
with open('logging_config.yml', 'rt') as f:
config = yaml.safe_load(f.read())
logging.config.dictConfig(config)
# create logger
logger = logging.getLogger(__name__)
# 'application' code
logger.debug('debug message')
logger.info('info message')
logger.warn('warn message')
logger.error('error message')
logger.critical('critical message')
Когда я запускаю test.py
, предполагается, что скрипт просто войдет в консоль, поскольку handler
для root
равно console
, но также создается пустой файл train.log. Почему это приложение?