我对Python比较陌生,我正在开发我的第一个Python GUI(慢慢地)。我想使用的第三方模块之一使用Python's logging
framework。我希望他们的日志转到GtkTextView
。我知道他们的logger
变量在哪里,因此可以调用logger.addHandler
。
如何正确地从logging.Handler
继承?
答案 0 :(得分:1)
我基于StreamHandler
来源的实施是
class GtkTextViewHandler(logging.Handler):
def __init__(self, tv):
logging.Handler.__init__(self)
self.tv = tv
self.tbf = tv.get_buffer()
self.formatter = None
def emit(self, record):
try:
msg = self.format(record)
fs = "%s\n"
self.tbf.insert(self.tbf.get_end_iter(), fs % msg)
self.tv.scroll_to_iter(self.tv.get_end_iter(), 0.0, False, 0, 0)
except:
self.handleError(record)