gpt4 book ai didi

python - 从 Python 中的不同类记录到多个日志文件

转载 作者:IT老高 更新时间:2023-10-28 20:57:16 28 4
gpt4 key购买 nike

我想编写一个使用 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

最佳答案

听起来你的类(class)内部应该有一个 Logger并且您需要添加 FileHandlerLogger。您可能只想考虑使用创建 Logger 并添加处理程序的工厂方法,而不是实现自己的类。您可能需要创建保存日志文件的目录。见 this answer获取有关创建目录的建议。

编辑:

我认为您不需要编写自己的 Logger 类。 Python 的 logging 模块有你需要的所有东西。您可能只需要一个工厂方法。实现的关键是您需要创建两个独立的、完全独立的日志记录对象。您可以使用 logging.getLogger 执行此操作,并且任何时候您传递一个不同的名称,它都会为您提供一个不同的记录器。您可以使用任何您想要的记录器名称。当然,您希望远离 basicConfig 您正在做的事情。它的设计目的是为那些只想要一个 Logger 而不做任何特别的事情的人提供一些简单的东西。

我认为这展示了您所追求的功能。关键是使用不同的处理程序创建两个不同的记录器。然后分别使用它们。请记住,我对 logging.getLogger 的第二次调用不会创建新的记录器;它得到了我们最初在 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:\temp\log1.log')
setup_logger('log2', r'C:\temp\log2.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:\Python\27\python.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!

关于python - 从 Python 中的不同类记录到多个日志文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17035077/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com