我创建了一个PyQt5网络应用,该应用使用以下代码导航到https://www.google.com/:
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtWebEngineWidgets import *
import sys
class MainWindow(QMainWindow):
def __init__(self, *args, **kwargs):
super(MainWindow, self).__init__(*args, **kwargs)
self.setWindowTitle("My Window")
self.browser = QWebEngineView()
self.browser.setUrl( QUrl("www.google.com") )
self.setCentralWidget(self.browse)
app = QApplication(sys.argv)
window = MainWindow()
window.show()
app.exec()
这个想法是,我想操纵应用程序内部的点击,因此要在google网站上进行操作,例如:将鼠标移动到某些位置(x,y),而不像pyautogui那样影响PC本身,这意味着我我可以在PC上执行正常操作而无需影响的情况下,可以运行在Web应用程序内部随机单击的代码。
我将很高兴知道这是否可能。如果是的话,怎么办?
注意:我真的没有python经验
答案 0 :(得分:1)
除非它是一个嵌入式应用程序,否则您始终可以通过请求HTML路径或通过JavaScript解析器来解析html,搜索按钮并“单击”按钮。
代码api之后看起来像
parsed_response.find(my_button).click()
如果您不坚持自己写书,那已经是selenium
了。
显示一个小例子
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
driver = webdriver.Chrome()
driver.get("www.website.com")
login_input = driver.find_element_by_id(id)
login_input.send_keys(my_login)
login_input.send_keys(Keys.ENTER)
# Or you can do something like
# submit_button = driver.find_element_by_id(submitbutton)
# submit_button.click()
硒的作用是巨大的,但是当我回答有关网络抓取的问题时,我总是将其作为注释。在与您的漫游器实际使用该网站之前,请先检查/robots.txt。
答案 1 :(得分:0)
您可以通过发送QMouseEvent来模拟单击,在QWebEngineView的情况下,应将单击发布到内部Qt API中,该内部窗口小部件是私有Qt API的一部分,但可以通过使用findChildren和QMetaObject的小逻辑来访问。 / p>
在下面的示例中,单击位置400、200,在我的情况下是一个Google标语,它将打开相应的信息。
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_())