gpt4 book ai didi

python - 我的日志记录类的奇怪行为

转载 作者:太空宇宙 更新时间:2023-11-03 18:52:05 25 4
gpt4 key购买 nike

我会尽力恢复。我写了这个类(class):

日志类

import logging, logging.handlers.TimedRotatingFileHandler

class Logger(object):
def __init__(self, log_filename):
logging.basicConfig(format='%(asctime)s %(message)s')
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')
loghandler = TimedRotatingFileHandler(
log_filename, when="midnight", backupCount=50
)
loghandler.setFormatter(formatter)
self.logger = logging.getLogger()
self.logger.setLevel(logging.INFO)
self.logger.addHandler(loghandler)

def getLogger(self):
return self.logger

它确实工作得很好,现在当我有一个使用 Logger 实例的脚本并且在该脚本中我实例化一个也使用 Logger 的类时,问题就出现了,如下所示:

脚本

import ClassA

A = ClassA()
log = Logger(log_filename='script_logger.log')
logger = log.getLogger()
logger.info('Initiated Script')

while True:
logger.info('Looping')
A.run()

我的类(class)是什么样的:

A类模块

class ClassA(object):
def __init__(self):
log = Logger(log_filename='class_logger.log')
self.logger = log.getLogger()
self.logger.info('Started ClassA')

def run(self):
self.logger.info('Into method run')

现在我希望有 2 个独立的日志文件,class_logger.logscript_logger.log 可以正常工作,但是这两个文件逐行具有完全相同的内容。

因此 script_logger.logclass_logger.log 具有以下内容:

Started classA
Initiated Script
Looping
Into method run
Looping
Into method run
...

有什么线索吗?

最佳答案

原因是当您执行logging.getLogger()时,类和脚本具有相同的记录器对象。这是一个单例。如果您想要不同的记录器,那么您应该传递记录器名称,例如logging.getLogger('logger1')通常图书馆会这样做logging.getLogger(__name__)以便每个模块都有不同的记录器。引用http://docs.python.org/2/library/logging.html#logger-objects

我已经修改了您的代码,使其现在可以按预期工作

import logging, logging.handlers
from logging.handlers import TimedRotatingFileHandler

class Logger(object):
def __init__(self, log_filename, name):
logging.basicConfig(format='%(asctime)s %(message)s')
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')
loghandler = TimedRotatingFileHandler(
log_filename, when="midnight", backupCount=50
)
loghandler.setFormatter(formatter)
self.logger = logging.getLogger(name)
self.logger.setLevel(logging.INFO)
self.logger.addHandler(loghandler)

def getLogger(self):
return self.logger


class ClassA(object):
def __init__(self):
log = Logger(log_filename='class_logger.log', name="Class")
self.logger = log.getLogger()
self.logger.info('Started ClassA')

def run(self):
self.logger.info('Into method run')


A = ClassA()
log = Logger(log_filename='script_logger.log', name="Script")
logger = log.getLogger()
logger.info('Initiated Script')

for x in range(5):
logger.info('Looping')
A.run()

关于python - 我的日志记录类的奇怪行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18117547/

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