我想编写一个使用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
Run Code Online (Sandbox Code Playgroud)
jpm*_*c26 54
听起来像是你的类也许应该有一个的内部Logger,并且你要一个添加FileHandler到Logger.您可能只想考虑使用创建Loggers 的工厂方法并添加处理程序而不是实现自己的类.您可能需要创建包含日志文件的目录.有关创建目录的建议,请参阅此答案.
编辑:
我认为你不需要写自己的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()
Run Code Online (Sandbox Code Playgroud)
样品运行:
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!
Run Code Online (Sandbox Code Playgroud)
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!
Run Code Online (Sandbox Code Playgroud)
log2.log:
2013-06-12 02:00:13,832 : Info for log 2!
Run Code Online (Sandbox Code Playgroud)