从__main __

时间:2018-03-07 08:59:06

标签: python-3.x logging main init

我正在尝试在我的项目中实现日志记录,并希望所有模块都记录到同一个文件中。如果我在 init 中设置记录器,我设法让它工作,但如果我在主要中设置它,则不然。当我在主要中进行设置时,它只记录来自 main 的语句,而不是其他模块。

我想在 main 中进行设置,以便我可以将记录器的配置放在config.py文件中的dictConfig中。当我从 init 执行此操作时,导入语句会出错。

这是___ main ____。py:

中的内容
import logging
from logging.config import dictConfig
import config as cfg

if __name__ == '__main__':
    dictConfig(cfg.logging)
    logger = logging.getLogger()
    logger.info('Completed configuring logger()!')
    main()

在config.py中:

logging = dict(
    version = 1,
    formatters = {
        'f': {'format':
              '%(asctime)s %(name)-12s %(levelname)-8s %(message)s'}
        },
    handlers = {
        'h': {'class': 'logging.StreamHandler',
              'formatter': 'f',
              'level': logging.INFO},
        'r': {'class': 'logging.handlers.RotatingFileHandler',
                'filename': 'data/logger.log',
                'formatter':'f',
              'maxBytes': 10000,
              'backupCount':5},
        },
    root = {
        'handlers': ['h', 'r'],
        'level': logging.INFO,
        },
)

在backend.py中:

import logging
logger = logging.getLogger(__name__)

class Backend(object):

    def __init__(self, dbi):
        self._dbi = dbi

    def getDimensionTableColumns(self, table_name):
        logger.warning('still not working')

我的logger.log文件和终端中的输出是:

2018-03-07 09:48:00,858 root         INFO     Completed configuring logger()!

我知道getDimensionTableColumns正在运行,因为如果我把一个print语句输出到终端。

有人可以解释一下出了什么问题吗?为什么?

1 个答案:

答案 0 :(得分:1)

您正在使用两个不同的记录器:__main__模块中的根记录器(已配置)(您使用logger = logging.getLogger()获得的记录器)和一个名为__name__ = 'backend'的记录器(这是不是)。

您可以使用

backend.py中使用默认记录器
logger = logging.getLogger()  # no __name__ !

或者您可以配置命名记录器并在两个模块中使用它。