gpt4 book ai didi

python - 我扩展 QApplication 并在 exec_ 之后调用方法不起作用

转载 作者:行者123 更新时间:2023-12-01 06:15:41 25 4
gpt4 key购买 nike

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

class Scrape(QApplication):  def __init__(self):    super(Scrape, self).__init__(None)    self.webView = QWebView()    self.webView.loadFinished.connect(self.loadFinished)  def load(self, url):    self.webView.load(QUrl(url))  def loadFinished(self):    documentElement = self.webView.page().currentFrame().documentElement()myScrape = Scrape()myScrape.load('http://google.com/ncr')myScrape.exec_()

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

最佳答案

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

load 方法执行您所期望的操作:在 View 中设置 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"

关于python - 我扩展 QApplication 并在 exec_ 之后调用方法不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3455260/

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