如何在 YAML 中指定始终使用 dictConfig 在项目文件夹中创建日志文件?

2024-01-11

在我的 Python 程序中,我有以下代码:

def main():
    # The file's path
    path = os.path.dirname(os.path.realpath(__file__))
    ...
    # Config file relative to this file
    loggingConf = open('{0}/configs/logging.yml'.format(path), 'r')
    logging.config.dictConfig(yaml.load(loggingConf))
    loggingConf.close()
    logger = logging.getLogger(LOGGER)
    ...

这是我的logging.yml配置文件:

version: 1
formatters:
  default:
    format: '%(asctime)s %(levelname)s %(name)s %(message)s'
handlers:
  console:
    class: logging.StreamHandler
    level: DEBUG
    formatter: default
    stream: ext://sys.stdout
  file:
    class : logging.FileHandler
    formatter: default
    filename: bot.log
loggers:
  cloaked_chatter:
    level: DEBUG
    handlers: [console, file]
    propagate: no

问题是 bot.log 文件是在程序启动时创建的。我希望它始终创建在项目的文件夹中,即与我的 Python 程序位于同一文件夹中。

例如,启动程序./bot.py将在同一文件夹中创建日志文件。但启动它python3 path/bot.py将在文件层次结构中创建高于 Python 程序级别的日志文件。

我应该如何在配置文件中写入文件名来解决这个问题?或者我需要编写一个自定义处理程序?如果是这样,怎么办?或者使用 dictConfig 无法解决这个问题?


有多种方法可以实现您想要的目标。例如,一种方法是为您的处理程序创建自定义初始化程序:

import os
import yaml

def logmaker():
    path = os.path.dirname(os.path.realpath(__file__))
    path = os.path.join(path, 'bot.log')
    return logging.FileHandler(path)

def main():
    # The file's path
    path = os.path.dirname(os.path.realpath(__file__))

    # Config file relative to this file
    loggingConf = open('{0}/logging.yml'.format(path), 'r')
    logging.config.dictConfig(yaml.load(loggingConf))
    loggingConf.close()
    logger = logging.getLogger('cloaked_chatter')
    logger.debug('Hello, world!')

if __name__ == '__main__':
    main()

请注意,我移动了logging.yml与脚本相邻。这logmaker是自定义初始化程序。在 YAML 中指定如下:

version: 1
formatters:
  default:
    format: '%(asctime)s %(levelname)s %(name)s %(message)s'
handlers:
  console:
    class: logging.StreamHandler
    level: DEBUG
    formatter: default
    stream: ext://sys.stdout
  file:
    () : __main__.logmaker
    formatter: default
loggers:
  cloaked_chatter:
    level: DEBUG
    handlers: [console, file]
    propagate: no

如果运行 Python 脚本,您应该会发现bot.log是在脚本和 YAML 文件旁边创建的。相同的消息被打印到控制台并且bot.log:

2013-04-16 11:08:11,178 DEBUG cloaked_chatter Hello, world!

注意:脚本可能会更简洁一些,但它说明了我的观点。

Update: As per 文档 http://docs.python.org/2/library/logging.config.html#user-defined-objects, 指某东西的用途()作为字典中的键表明该值是可调用的,本质上是处理程序的自定义构造函数。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何在 YAML 中指定始终使用 dictConfig 在项目文件夹中创建日志文件? 的相关文章

随机推荐