gpt4 book ai didi

python - 如何继承logging.Handler来记录到GtkTextView?

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

我对 Python 比较陌生,我正在开发我的第一个 Python GUI(缓慢地)。我想使用的第三方模块之一使用 Python's logging framework 。我希望他们的日志转到 GtkTextView。我知道他们的 logger 变量在哪里,因此可以调用 logger.addHandler。

如何正确继承logging.Handler

最佳答案

我基于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)

关于python - 如何继承logging.Handler来记录到GtkTextView?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11881795/

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