在Python中记录来自不同类的多个日志文件

我想编写一个使用Python日志记录的Python类。 这个Python类将负责在init函数中创建一个具有给定名称的文件。

我想在两个或多个类中创建上述类的对象,并期望生成两个或多个文件。

我试着写这个类,但我无法创建多个文件。

任何人都可以指导我如何做到这一点?

我创建了以下课程:

class Logger:
def __init__(self, log_filename = "test.log"):
    if not os.path.exists("LogFiles"):
        os.makedirs("LogFiles")
    self.Logger = logging.getLogger("main")
    logging.basicConfig(level=logging.DEBUG,
                        format='%(asctime)s : %(message)s',
                        filename= log_filename,
                        filemode='w')           # change filemode to 'w' to overwrite file on each run

    consoleHandler = logging.StreamHandler()
    consoleHandler.setLevel(logging.DEBUG)
    formatter = logging.Formatter('%(asctime)s - %(message)s')
    consoleHandler.setFormatter(formatter)
    logging.getLogger('').addHandler(consoleHandler)      # Add to the root logger
    self.Logger.info("Starting new logging sessions")


def writeToFile(self, line):
    if self.Logger.propagate == True:
        self.Logger.debug(line)

def closeFile(self):

    if self.Logger.propagate == True:
        self.Logger.propagate = False

听起来你的班级的内部应该可能有一个Logger ,你会想要添加一个FileHandlerLogger 。 您可能需要考虑使用创建Logger的工厂方法,并添加处理程序而不是实现自己的类。 您可能需要创建包含日志文件的目录。 有关创建目录的建议,请参阅此答案。

编辑:

我不认为你需要编写你自己的Logger类。 Python的logging模块包含您需要的所有内容。 你可能只需要一个工厂方法。 要实现的关键是你需要创建两个独立的,完全独立的日志记录对象。 你可以使用logging.getLogger做到这一点,并且只要你通过一个不同的名字,它就会给你一个不同的记录器。 您可以使用任何您想要的记录器名称。 当然,你希望远离basicConfig因为你正在做的事情。 它的设计对那些只希望一个Logger不做任何特别事情的人来说很简单。

我认为这演示了你所追求的功能。 关键是用不同的处理程序创建两个不同的记录器。 然后分开使用它们。 请记住,我对logging.getLogger第二次调用不会创建新的记录器; 它得到了我们最初在setup_logger设置的setup_logger

log_test.py:

from __future__ import absolute_import

import logging

def setup_logger(logger_name, log_file, level=logging.INFO):
    l = logging.getLogger(logger_name)
    formatter = logging.Formatter('%(asctime)s : %(message)s')
    fileHandler = logging.FileHandler(log_file, mode='w')
    fileHandler.setFormatter(formatter)
    streamHandler = logging.StreamHandler()
    streamHandler.setFormatter(formatter)

    l.setLevel(level)
    l.addHandler(fileHandler)
    l.addHandler(streamHandler)    

def main():
    setup_logger('log1', r'C:templog1.log')
    setup_logger('log2', r'C:templog2.log')
    log1 = logging.getLogger('log1')
    log2 = logging.getLogger('log2')

    log1.info('Info for log 1!')
    log2.info('Info for log 2!')
    log1.error('Oh, no! Something went wrong!')

if '__main__' == __name__:
    main()

样品运行:

C:temp>C:Python27python.exe logtest.py
2013-06-12 02:00:13,832 : Info for log 1!
2013-06-12 02:00:13,832 : Info for log 2!
2013-06-12 02:00:13,832 : Oh, no! Something went wrong!

log1.log:

2013-06-12 02:00:13,832 : Info for log 1!
2013-06-12 02:00:13,832 : Oh, no! Something went wrong!

log2.log:

2013-06-12 02:00:13,832 : Info for log 2!
链接地址: http://www.djcxy.com/p/9273.html

上一篇: Logging to multiple log files from different classes in Python

下一篇: Automatically creating directories with file output