您可以通过发送 QMouseEvent 来模拟单击,在 QWebEngineView 的情况下,单击应该被发出到作为私有 Qt API 的一部分但可以访问的内部小部件:使用 findChildren 和 QMetaObject。
在下面的示例中,单击位置 400、200,在我的例子中是一个谷歌横幅,它将打开相应的信息。
import sys
from PyQt5 import QtCore, QtGui, QtWidgets, QtWebEngineWidgets
class MainWindow(QtWidgets.QMainWindow):
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
self.setWindowTitle("My Window")
self.browser = QtWebEngineWidgets.QWebEngineView()
self.browser.setUrl(QtCore.QUrl("https://www.google.com/"))
self.setCentralWidget(self.browser)
self.browser.loadFinished.connect(self.on_loadFinished)
@QtCore.pyqtSlot(bool)
def on_loadFinished(self, ok):
if not ok:
return
w = None
for child in self.browser.findChildren(QtWidgets.QWidget):
if (
child.metaObject().className()
== "QtWebEngineCore::RenderWidgetHostViewQtDelegateWidget"
):
w = child
break
if w is not None:
self.emulate_click(w, QtCore.QPoint(400, 200))
def emulate_click(self, widget, pos):
event_press = QtGui.QMouseEvent(
QtCore.QEvent.MouseButtonPress,
pos,
QtCore.Qt.LeftButton,
QtCore.Qt.LeftButton,
QtCore.Qt.NoModifier,
)
QtCore.QCoreApplication.postEvent(widget, event_press)
event_release = QtGui.QMouseEvent(
QtCore.QEvent.MouseButtonRelease,
pos,
QtCore.Qt.LeftButton,
QtCore.Qt.LeftButton,
QtCore.Qt.NoModifier,
)
QtCore.QCoreApplication.postEvent(widget, event_release)
if __name__ == "__main__":
app = QtWidgets.QApplication(sys.argv)
w = MainWindow()
w.resize(640, 480)
w.show()
sys.exit(app.exec_())
如果您有更多信息,例如 id 或 xpath,您可以使用 javascript 点击:
import sys
from PyQt5 import QtCore, QtGui, QtWidgets, QtWebEngineWidgets
class MainWindow(QtWidgets.QMainWindow):
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
self.setWindowTitle("My Window")
self.browser = QtWebEngineWidgets.QWebEngineView()
self.browser.setUrl(QtCore.QUrl("https://www.google.com/"))
self.setCentralWidget(self.browser)
self.browser.loadFinished.connect(self.on_loadFinished)
@QtCore.pyqtSlot(bool)
def on_loadFinished(self, ok):
if not ok:
return
xpath = r"//body[@id='gsr']/div[@id='viewport']/div[@id='main']/span[@id='body']/center/div[@id='lga']/div[@id='hplogo']/a/img[1]"
s = (
"""
(function() {
var banner = document.evaluate("%s", document, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue;
banner.click()
})()"""
% xpath
)
self.browser.page().runJavaScript(s)
if __name__ == "__main__":
app = QtWidgets.QApplication(sys.argv)
w = MainWindow()
w.resize(640, 480)
w.show()
sys.exit(app.exec_())