gpt4 book ai didi

使用 Qt 运行日志流送器时 Python 崩溃

转载 作者:行者123 更新时间:2023-12-03 12:45:27 30 4
gpt4 key购买 nike

目标

我有一个在运行时记录文件 (realtime.log) 的进程,我想在我的应用程序中实时打印该文件的每一行。换句话说,我想将进程的输出重定向到 GUI。这意味着我正在运行两个不同的进程:“引擎”和 GUI。

我已经通过使用 Tkinter 实现了这一点,但由于我必须制作更复杂、更专业、更美观的 GUI,我决定切换到 Qt for Python (PySide2)。

问题

当我启动 GUI 时,Python 经常 崩溃并显示错误消息:Python 已停止工作。窗口开始打印线条,然后在某个时候停止工作。

经过多次尝试和搜索后,我发现只有在单击 GUI 窗口时程序才会崩溃。此外,程序不会突然崩溃,而是在引擎执行结束时崩溃。

环境

  • Windows 10
  • python 3.6.5
  • PySide2 5.12.6

代码

请注意,这是一个简化版本。

datalog_path = "realtime.log"


def get_array_from_file(file_path):
try:
with open(file_path, 'r') as file:
lines = file.readlines()
return lines
except:
print('error in file access')


class Streamer(QRunnable):
def __init__(self, stream, old_array, edit):
super().__init__()
self.stream = stream
self.old_array = old_array
self.edit = edit

def run(self):
try:
while self.stream:
array_file = get_array_from_file(datalog_path)
if len(array_file) != len(self.old_array):
for line in array_file[len(self.old_array) - 1:len(array_file)]:
self.edit.append(line)
# print(line)
self.old_array.append(line)
except:
print('problem in streaming funct')


class Window(QMainWindow):
def __init__(self):
super().__init__()
layout = QVBoxLayout()

self.setWindowTitle("DATALOG")
self.thread_pool = QThreadPool()
self.edit = QTextEdit()

self.stream = True
self.old_array = get_array_from_file(datalog_path)
self.streamer = Streamer(self.stream, self.old_array, self.edit)
self.thread_pool.start(self.streamer)

window = QWidget()
layout.addWidget(self.edit)
window.setLayout(layout)
self.setCentralWidget(window)


def closeEvent(self, event):
self.stream = False
event.accept()


if __name__ == '__main__':
app = QApplication(sys.argv)
win = Window()
win.show()
app.exec_()

最佳答案

@hyde answer指出解释了问题的原因,但其解决方案不适用于 PySide2(在 PyQt5 中必须进行小的修改,请参阅 this),另一种方法是创建具有信号的 QObject:

class Signaller(QtCore.QObject):
textChanged = Signal(str)
class Streamer(QRunnable):
def __init__(self, stream, old_array):
super().__init__()
self.stream = stream
self.old_array = old_array
<b>self.signaller = Signaller()</b>

def run(self):
try:
while self.stream:
array_file = get_array_from_file(datalog_path)
if len(array_file) != len(self.old_array):
for line in array_file[len(self.old_array) - 1:len(array_file)]:
<b>self.signaller.textChanged.emit(line)</b>
# print(line)
self.old_array.append(line)
except:
print('problem in streaming funct')
self.stream = True
self.old_array = get_array_from_file(datalog_path)
<b>self.streamer = Streamer(self.stream, self.old_array)
self.streamer.signaller.textChanged.connect(self.edit.append)</b>
self.thread_pool.start(self.streamer)

关于使用 Qt 运行日志流送器时 Python 崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62875067/

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