我扩展 QApplication 并在 exec_ 后调用一个方法不起作用

Posted

技术标签:

【中文标题】我扩展 QApplication 并在 exec_ 后调用一个方法不起作用【英文标题】:I extend QApplication and calling a method after exec_ does not work 【发布时间】:2011-03-28 04:23:54 【问题描述】:

以下代码有效(而且非常简单):

类刮(QApplication): def __init__(self): 超级(刮擦,自我).__init__(无) self.webView = QWebView() self.webView.loadFinished.connect(self.loadFinished) 定义加载(自我,网址): self.webView.load(QUrl(url)) def loadFinished(self): documentElement = self.webView.page().currentFrame().documentElement() 我的刮 = 刮() myScrape.load('http://google.com/ncr') myScrape.exec_()

但我真的不明白为什么 exec_() 需要成为最后一次调用,如果需要,那么 load() 真正做了什么......?如果我需要加载,比如说,两个网页,这将如何工作?

【问题讨论】:

【参考方案1】:

exec_ 调用启动事件循环。这是分配键盘和鼠标事件、计时器事件以及异步槽调用的地方。

load 方法做了你所期望的:在视图中设置 Url。这不需要处理事件即可工作。但是如果你没有完成exec_,就没有什么可以处理事件,或者阻止程序刚刚完成并退出。

exec_ 方法,正如术语“事件循环”所示,循环直到应用程序退出。在事件循环退出之前,不会调用之后调用的函数。

如果您想在您的程序中“做事”,通常您会在事件驱动框架内工作。要加载页面,您可能会连接一个触发事件的按钮,该事件连接到加载不同页面的函数。或者,您可以设置一个计时器,该计时器调用一个从列表中设置 URL 的函数。

连接信号和槽的示例(来自here):

# Define a new signal called 'trigger' that has no arguments.
trigger = QtCore.pyqtSignal()

def connect_and_emit_trigger(self):
    # Connect the trigger signal to a slot.
    self.trigger.connect(self.handle_trigger)

    # Emit the signal.
    self.trigger.emit()

def handle_trigger(self):
    # Show that the slot has been called.

    print "trigger signal received"

【讨论】:

那么 exec_() 是否会触发信号...?或者上面是你在 exec_() 之前做某事并使用结果发出的信号的正确方法? 是的,后者。我知道没有任何“应用程序启动”信号,但如果您在 init 方法中触发信号,它应该在启动时排队并由事件循环处理.查找“QEventLoop”和“QCoreApplication::processEvents” @sje397,我不明白如何将您的代码集成到问题上的代码中。你如何添加一些胶水代码?

以上是关于我扩展 QApplication 并在 exec_ 后调用一个方法不起作用的主要内容,如果未能解决你的问题,请参考以下文章

在循环中多次调用 Qapplication.exec 是可能的。如果是,如何?

有没有办法在没有 QApplication::exec() 的情况下使用 Qt?

退出信号未在 PyQt 中捕获

PyQt:app.exec_() 停止运行以下所有代码

完全删除 QApplication 实例并在另一个线程中重新创建它

非主线程中的QApplication