Pylint消息:无效的常量名称(无效名称)

时间:2015-10-11 18:07:31

标签: python pylint

在记录器功能的简写中,Pylint抱怨Invalid constant name "myprint" (invalid-name)

# import
from utils import get_logger
LOGFILE = '6_evaluator.log'
myprint = get_logger(LOGFILE)

def main():
    # some stuff
    myprint('log log')

if __name__ == '__main__':
    main()

这可以在不调整pylint配置的情况下完成吗?

如果需要,以下是get_logger的定义:

import logging
import os

def get_logger(logfile):
    """ Return a logger that log on stdout and in LOGFILE"""
    if os.path.isfile('{}'.format(logfile)):
        os.remove('{}'.format(logfile))

    logging.basicConfig(filename='{}'.format(logfile), level=logging.INFO)
    logger = logging.getLogger('')
    logger.addHandler(logging.StreamHandler())
    myprint = logger.info

    myprint('log file at: {}'.format(logfile))
    myprint('Again Hello from logger')
    return myprint

2 个答案:

答案 0 :(得分:19)

myprint的定义移至main()是抑制消息的一种方法。

Per Pylint docs for invalid-name (C0103),似乎常量的名称必须有效地为大写。因此,名称MYPRINT将不会生成消息。

如果您将以下注释附加到该行,则不应生成该消息。

log = get_logger()  # pylint: disable=locally-disabled, invalid-name

或者,将以下内容添加到项目的.pylintrc。这是我的首选解决方案。

[BASIC]
good-names=log

如果您希望整个无效名称模式(而不仅仅是单个名称)有效,则可以在同一部分中自定义const-rgx等。请参阅之前链接的pylint页面。

最后,如果您的应用程序很小且独立,您只需配置和使用根记录器,例如使用logging.warn('test')

答案 1 :(得分:2)

问题在于您是在模块级别定义myprint。

如果您在main中定义它,则不会从pylint中获得此错误。