gpt4 book ai didi

python - QObject::connect: 无法对类型为 'QTextCursor' 的参数进行排队

转载 作者:太空宇宙 更新时间:2023-11-04 01:31:24 27 4
gpt4 key购买 nike

我试图从 PyQt 中的非主线程发送信号,但我不知道哪里做错了!当我执行程序时,它因以下错误而失败:

QObject::connect: Cannot queue arguments of type 'QTextCursor'
(Make sure 'QTextCursor' is registered using qRegisterMetaType().)

这是我的代码:

 class Sender(QtCore.QThread):
def __init__(self,q):
super(Sender,self).__init__()
self.q=q
def run(self):

while True:
pass
try: line = q.get_nowait()
# or q.get(timeout=.1)
except Empty:
pass
else:
self.emit(QtCore.SIGNAL('tri()'))
class Workspace(QMainWindow, Ui_MainWindow):
""" This class is for managing the whole GUI `Workspace'.
Currently a Workspace is similar to a MainWindow
"""

def __init__(self):
try:
from Queue import Queue, Empty
except ImportError:
while True:
#from queue import Queue, Empty # python 3.x
print "error"

ON_POSIX = 'posix' in sys.builtin_module_names

def enqueue_output(out, queue):
for line in iter(out.readline, b''):
queue.put(line)
out.close()

p= Popen(["java -Xmx256m -jar bin/HelloWorld.jar"],cwd=r'/home/karen/sphinx4-1.0beta5-src/sphinx4-1.0beta5/',stdout=PIPE, shell=True, bufsize= 4024)
q = Queue()
t = threading.Thread(target=enqueue_output, args=(p.stdout, q))
t.daemon = True # thread dies with the program
t.start()
self.sender= Sender(q)
self.connect(self.sender, QtCore.SIGNAL('tri()'), self.__action_About)
self.sender.start()

我认为我向线程发送参数的方式是错误的...我需要知道如何将参数发送到线程,在我的例子中,我需要将 q 发送到工作线程。

最佳答案

PyQt5 很新,但是当您尝试从不是“应用程序线程”的线程执行 GUI 操作时,这似乎会发生。我把它放在引号中是因为认为即使在相当简单的 PyQt5 应用程序中,QApplication.instance().thread() 也将始终返回相同的对象似乎是错误的。

要做的事情是使用信号/槽机制从工作线程发送任何类型的数据(在我的例子中通过扩展 QtCore.QRunnable 创建的线程,另一种模式显然是QtCore.QThreadQtCore.QObject.moveToThread,参见 here)。

然后还检查所有可能从非“应用程序线程”接收数据的插槽方法。在执行期间以可视方式记录消息的示例:

def append_message(self, message):
# this "instance" method is very useful!
app_thread = QtWidgets.QApplication.instance().thread()
curr_thread = QtCore.QThread.currentThread()
if app_thread != curr_thread:
raise Exception('attempt to call MainWindow.append_message from non-app thread')
ms_now = datetime.datetime.now().isoformat(sep=' ', timespec='milliseconds')
self.messages_text_box.insertPlainText(f'{ms_now}: {message}\n')
# scroll to bottom
self.messages_text_box.moveCursor(QtGui.QTextCursor.End)

从非“应用程序线程”无意中直接调用它太容易了。

犯这样的错误然后引发异常是好的,因为它会为您提供显示错误调用的堆栈跟踪。然后更改调用,以便它改为向 GUI 类发送一个信号,其插槽可以是 GUI 类中的方法(此处为 append_message),或者一个 依次 调用 append_message

在我的示例中,我在上面包含了“滚动到底部”行,因为只有当我添加该行时,这些“无法排队”错误才开始发生。换句话说,完全有可能在不引发任何错误的情况下摆脱一定数量的不合规处理(在本例中为每次调用添加更多文本)……只是稍后您才会遇到困难。为防止这种情况,我建议具有 GUI 功能的 GUI 类中的每个方法都应该包括这样的检查!

关于python - QObject::connect: 无法对类型为 'QTextCursor' 的参数进行排队,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13674792/

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