使用流重定向python日志消息

时间:2013-08-23 14:21:54

标签: python logging stream handler stringio

我想将日志消息重定向到某种处理方法(例如,按顺序保存队列中的所有消息)。目前我正在尝试使用logging.StreamHandler来写入StringIO,然后在其他地方读取它。在我的情况下,这可能是一个连续从流中读取的线程,但它也可能是在每个日志条目上调用的回调方法。

import threading
import time
import sys
import logging
from StringIO import StringIO

# this thread shall read from a stream 
# continuously and 
def tread_fn( stream ):
    while not stream.eof():       <=== this is not valid but my current approach
        l = stream.readline()
        do_something( l )

stream = StringIO()

handler = logging.StreamHandler(stream)
log = logging.getLogger()
log.setLevel( logging.INFO )

# replace all log handlers
for handler in log.handlers: 
    log.removeHandler(handler)
log.addHandler(handler)

thread = threading.Thread(target = tread_fn, args=[stream])
thread.start()

for i in range(3):        
    time.sleep(1)
    log.error("test")          <=== should be handled line by line

我觉得我忽略了非常明显和简单的最佳做法,但我现在已经挣扎了一段时间:) 也许我根本不需要流,但是目前我甚至没有写入流并在其他地方读取它。 所以简而言之,我的问题是:

  • 主要目标如何实现python方式?

  • 如何将字符串写入流并在另一个线程中不断读取它?

1 个答案:

答案 0 :(得分:0)

你在一个问题中提出了两个问题 - 它们应该是单独的问题。您的主要目标可以使用例如一个QueueHandler,可在Python 3.2及更高版本中使用,但也可通过logutils项目用于早期的Python版本。