Python日志记录:使用更改保存位置记录配置文件

时间:2012-10-21 04:34:27

标签: python logging python-2.7 config

假设我有以下配置日志文件:

[loggers]
keys=root,seeker,event

[handlers]
keys=consoleHandler,seekerFileHandler,eventFileHandler

[formatters]
keys=consoleFormatter,logFormatter

[logger_root]
level=DEBUG
handlers=consoleHandler,seekerFileHandler,eventFileHandler

[logger_seeker]
level=DEBUG
handlers=consoleHandler,seekerFileHandler
qualname=seeker
propagate=0

[logger_event]
level=DEBUG
handlers=consoleHandler,eventFileHandler
qualname=event
propagate=0

[handler_consoleHandler]
class=StreamHandler
level=INFO
formatter=consoleFormatter
args=(sys.stdout,)

[handler_seekerFileHandler]
class=FileHandler
level=DEBUG
formatter=logFormatter
args=('seeker.log','a')

[handler_eventFileHandler]
class=FileHandler
level=DEBUG
formatter=logFormatter
args=('event.log','a')

[formatter_consoleFormatter]
format=%(asctime)s - thread:%(thread)d - %(name)s - %(levelname)s | %(message)s
datefmt=%m/%d/%Y %X

[formatter_logFormatter]
format=%(asctime)s | %(message)s
datefmt=%m/%d/%Y %X

通常我会:

import logging
from logging.config import fileConfig
from os import getcwd

fileConfig(''.join([getcwd(),'/logging.conf']))
event_logger = logging.getLogger("event")
seeker_logger = logging.getLogger("seeker")

处理每个记录器。但是,我倾向于在两个独立的平台上运行这个软件:Windows和Linux,如果他们每个人都将它保存在“公共”位置,那就太好了。我正在寻找的是:

from sys import platform
if 'win' in platform:
    #alter the save path to this location
if 'linux' in platform:
    #alter save path to this location

但我不知道如何使用配置文件实现这一点,任何想法?

1 个答案:

答案 0 :(得分:1)

您有2个选项。

  1. 使用带有不同路径的logging-linux.conf文件和logging-win.conf文件,并将其加载到平台测试中。

  2. 而不是使用配置文件,将logger的创建委托给您自己的模块,并在创建FileHandler实例时进行平台测试。

  3. 采用的解决方案取决于代码的复杂程度。如果您要构建库,请查看此页面:http://docs.python.org/howto/logging.html#configuring-logging-for-a-library