NameError:未定义全局名称“记录器”

Posted

技术标签:

【中文标题】NameError:未定义全局名称“记录器”【英文标题】:NameError: global name 'logger' is not defined 【发布时间】:2018-02-13 22:27:05 【问题描述】:

我编写了一个 logging.json 文件,在其中设置了日志记录配置,之后我创建了一个类,其中我的所有方法都将在那里,但是当我在类中使用记录器时,它会抛出错误 NameError: global name 'logger' is not defined

app.py

#/usr/bin/python

import sys
import logging
import time
import json
import os
import logging.config

def setup_logging(default_path='logging.json',default_level=logging.INFO,env_key='LOG_CFG'):
    """Setup logging configuration"""
    path = default_path
    value = os.getenv(env_key, None)
    if value:
        path = value
    if os.path.exists(path):
        with open(path, 'rt') as f:
            config = json.load(f)
        logging.config.dictConfig(config)
    else:
        logging.basicConfig(level=default_level)

class Generic:

        def __init__(self , file_path):
                self.file_path = file_path

        def check_mime(self):
                logger.info('Generic on file  starts at '.format(file_path , time.time()))


print 'File path is '.format(sys.argv[1])
file_path = sys.argv[1]

def parser():
        parser = Generic(file_path)
        parser.check_mime()
def main():
        print 'This is intended for module purpose only'
        setup_logging()
        parser()

if __name__ == '__main__':
        main()

logging.json


    "version": 1,
    "disable_existing_loggers": false,
    "formatters": 
        "simple": 
            "format": "%(asctime)s - %(name)s - %(levelname)s - %(message)s"
        
    ,

    "handlers": 
        "console": 
            "class": "logging.StreamHandler",
            "level": "DEBUG",
            "formatter": "simple",
            "stream": "ext://sys.stdout"
        ,

        "info_file_handler": 
            "class": "logging.handlers.RotatingFileHandler",
            "level": "INFO",
            "formatter": "simple",
            "filename": "logs/gp.log",
            "maxBytes": 10485760,
            "backupCount": 20,
            "encoding": "utf8"
        ,

        "error_file_handler": 
            "class": "logging.handlers.RotatingFileHandler",
            "level": "ERROR",
            "formatter": "simple",
            "filename": "logs/errors.log",
            "maxBytes": 10485760,
            "backupCount": 20,
            "encoding": "utf8"
        
    ,

    "loggers": 
        "my_module": 
            "level": "ERROR",
            "handlers": ["console"],
            "propagate": "no"
        
    ,

    "root": 
        "level": "INFO",
        "handlers": ["console", "info_file_handler", "error_file_handler"]
    

问题:

当我运行程序时出错

$ python app.py /home/default/domain.txt
File path is /home/default/domain.txt
This is intended for module purpose only
Traceback (most recent call last):
  File "app.py", line 44, in <module>
    main()
  File "app.py", line 41, in main
    parser()
  File "app.py", line 37, in parser
    parser.check_mime()
  File "app.py", line 29, in check_mime
    logger.info('GenericParser
NameError: global name 'logger' is not defined

我正在使用此链接 [https://fangpenlin.com/posts/2012/08/26/good-logging-practice-in-python/] 中的日志记录示例

关于如何解决这个问题的任何建议,因为记录器不是全球性的,有什么方法可以使它成为全球性的。?

【问题讨论】:

无需将其设为全球性。将logger = logging.getLogger(__name__) 放在每个使用日志记录的模块的顶部。 每个日志信息也打印到标准输出?有什么办法吗? 【参考方案1】:

您链接到的示例有:

import logging
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger(__name__) #<<<<<<<<<<<<<<<<<<<<

您错过了logger 定义。

您可以将self.logger = logging.getLogger(__name__) 放入Generic.__init__() 函数中,或者在导入后立即定义一个全局logger,如示例中所示。

【讨论】:

这里不需要global,因为您不会在方法中重新分配logger 好点。我总是不确定何时使用 global 关键字以及何时将其排除在外,尽管在这种情况下,我认为明确 logger 的来源是有益的 creat_app 工厂模式如何设置全局记录器? 如果我在__init__.py 中定义logger=logging.getLogger(__name__),我会在后续调用中使用记录器还是登录? logger 是你的变量,所以你应该使用那个。【参考方案2】:

以下内容应添加到您的代码中

logger=None
def setup():
   logger.debug('put some text')
   return 0

def main():
   global logger
   logger = logging.getLogger('give_some_logger_name')
   logger.setLevel(logging.DEBUG)

   ret = setup()

【讨论】:

【参考方案3】:

在您的班级中,您正在使用记录器,但您尚未定义它。 将记录器设置为:

    logger = logging.getLogger(__name__)

或改用日志记录:

    logging.info('Generic on file  starts at '.format(file_path , time.time()))

【讨论】:

以上是关于NameError:未定义全局名称“记录器”的主要内容,如果未能解决你的问题,请参考以下文章

NameError:未定义全局名称“reduce”

熊猫不进口吗? 'NameError:未定义全局名称'pandas''

NameError:未定义全局名称“QColor”

NameError:未定义全局名称“lower”

NameError:未定义全局名称

DD.close() NameError: 全局名称 'DD' 未定义