摘要:概要應同學邀請,演示如何使用內嵌瀏覽器瀏覽網頁,并注入腳本實現自動化操作。在默認配置中植入內容,這樣腳本會在所有打開的網頁中執行,不論跳轉到哪個網址。腳本使用網址中的路徑名,判斷當前網頁位置,從而決定執行哪種操作。
概要
應同學邀請,演示如何使用 PyQt5 內嵌瀏覽器瀏覽網頁,并注入 Javascript 腳本實現自動化操作。
sg 原貼地址: 如何在Python利用runJavaScript模擬鼠標移動頁面的某個元素
https://segmentfault.com/q/10...
下面測試的是一個廉價機票預訂網站(http://www.flyscoot.com/),關鍵點如下
使用 QWebEngineView 加載網頁,并顯示進度。
在默認配置(QWebEngineProfile)中植入 Javascript 內容,這樣腳本會在所有打開的網頁中執行,不論跳轉到哪個網址。
Javascript 腳本使用網址中的路徑名,判斷當前網頁位置,從而決定執行哪種操作。
python 代碼示例#!/usr/bin/env python3 # -*- coding: utf-8 -*- """使用 PyQt5 內嵌瀏覽器瀏覽網頁,并注入 Javascript 腳本實現自動化操作。""" import os import sys from datetime import datetime from PyQt5.QtWidgets import ( QWidget, QApplication, QVBoxLayout, QHBoxLayout, QDesktopWidget, QTextEdit, QLabel, QLineEdit, QPushButton, QFileDialog, QProgressBar, ) from PyQt5.QtCore import QUrl, pyqtSlot from PyQt5.QtWebEngineWidgets import QWebEngineView, QWebEngineProfile, QWebEngineScript, QWebEnginePage class Browser(QWidget): def __init__(self): super().__init__() self.init_ui() # 腳本 self.profile = QWebEngineProfile.defaultProfile() self.script = QWebEngineScript() self.prepare_script() def init_ui(self): self.webView = QWebEngineView() self.logEdit = QTextEdit() self.logEdit.setFixedHeight(100) self.addrEdit = QLineEdit() self.addrEdit.returnPressed.connect(self.load_url) self.webView.urlChanged.connect( lambda i: self.addrEdit.setText(i.toDisplayString())) self.jsEdit = QLineEdit() self.jsEdit.setText("inject.js") loadUrlBtn = QPushButton("加載") loadUrlBtn.clicked.connect(self.load_url) chooseJsBtn = QPushButton("選擇腳本文件") chooseJsBtn.clicked.connect(self.choose_js_file) # 導航/工具 top = QWidget() top.setFixedHeight(80) topBox = QVBoxLayout(top) topBox.setSpacing(0) topBox.setContentsMargins(5, 0, 0, 5) progBar = QProgressBar() progBox = QHBoxLayout() progBox.addWidget(progBar) topBox.addLayout(progBox) naviBox = QHBoxLayout() naviBox.addWidget(QLabel("網址")) naviBox.addWidget(self.addrEdit) naviBox.addWidget(loadUrlBtn) topBox.addLayout(naviBox) naviBox = QHBoxLayout() naviBox.addWidget(QLabel("注入腳本文件")) naviBox.addWidget(self.jsEdit) naviBox.addWidget(chooseJsBtn) topBox.addLayout(naviBox) self.webView.loadProgress.connect(progBar.setValue) # 主界面 layout = QVBoxLayout(self) layout.addWidget(self.webView) layout.addWidget(top) layout.addWidget(self.logEdit) self.show() self.resize(1024, 900) self.center() def center(self): qr = self.frameGeometry() cp = QDesktopWidget().availableGeometry().center() qr.moveCenter(cp) self.move(qr.topLeft()) @pyqtSlot() def load_url(self): url = self.addrEdit.text().strip() if not url.lower().startswith("http://") and not url.lower().startswith("https://"): url = "http://{}".format(url) self.load(url) @pyqtSlot() def choose_js_file(self): f, _ = QFileDialog.getOpenFileName(filter="Javascript files(*.js)") if os.path.isfile(f): self.jsEdit.setText(f) self.prepare_script() def prepare_script(self): path = self.jsEdit.text().strip() if not os.path.isfile(path): self.log("invalid js path") return self.profile.scripts().remove(self.script) with open(path, "r") as f: self.script.setSourceCode(f.read()) self.profile.scripts().insert(self.script) self.log("injected js ready") def log(self, msg, *args, **kwargs): m = msg.format(*args, **kwargs) self.logEdit.append("{} {}".format( datetime.now().strftime("%H:%M:%S"), m)) def load(self, url): self.log(f"loading {url}") self.addrEdit.setText(url) self.webView.load(QUrl(url)) if __name__ == "__main__": app = QApplication(sys.argv) b = Browser() b.load("http://www.flyscoot.com/") sys.exit(app.exec_())Javascript 腳本示例
// 簡單起見,這里只演示部分頁面,腳本內容摘自 Heng丶原貼文。 function handle(path) { // 首頁 if (path == "/zh") { document.getElementsByClassName("radio-inline")[1].click(); document.getElementById("oneway_from").value="廣州 (CAN)"; document.getElementById("oneway_to").value="新加坡 (SIN)"; document.getElementById("oneway_departuredate").value="2018年9月10日"; document.getElementsByClassName("btn--booking")[1].click(); return; } // 選擇航班 if (path == "/Book/Flight") { document.getElementsByClassName("price--sale")[0].click(); document.getElementsByClassName("heading-4")[0].click(); document.getElementsByClassName("btn-submit")[0].click(); return; } // 乘客信息 if (path == "/BookFlight/Passengers") { document.getElementsByClassName("fname1")[0].value = "匿名"; } } let host = document.location.hostname; if (host.endsWith(".flyscoot.com")) { handle(document.location.pathname); }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/42341.html
摘要:跨域請求跨域問題,是開發中一直以來需要注意的問題。則發送通道的發送給監聽此消息的外部擴展。完整方法此處,為必選參數,為回調函數?;卣{函數接收到的參數有三個,分別是和,即消息內容,消息發送者相關信息和相應函數。是發起消息的標簽。 第二章簡介 第二章較第一章復雜許多。書中雖寥寥21頁,內容卻也不少。涵蓋了8個小節。 2.1 操作用戶正在瀏覽的頁面 2.2 跨域請求 2.3 常駐后臺 2....
摘要:在瀏覽區中的性能,可以認為是開發者所面臨的最嚴重的可用性問題。優化這個問題的第一步從它的加載和執行開始。這意味著在對象的事件觸發后再下載腳本。屬性指明本元素所含的腳本不會修改,因此代碼能夠安全地執行,但是瀏覽器的支持情況不理想。 JavaScript在瀏覽區中的性能,可以認為是開發者所面臨的最嚴重的可用性問題。 優化這個問題的第一步從它的加載和執行開始。 霸道的script標簽scr...
摘要:是代替用戶完成指定的動作,需要知道其他用戶頁面的代碼和數據包。 常見web安全及防護原理 sql注入原理 就是通過把SQL命令插入到Web表單遞交或輸入域名或頁面請求的查詢字符串,最終達到欺騙服務器執行惡意的SQL命令 總的來說有以下幾點 永遠不要信任用戶的輸入,要對用戶的輸入進行校驗,可以通過正則表達式,或限制長度,對單引號和雙-進行轉換等 永遠不要使用動態拼裝SQL,可以...
閱讀 2642·2021-10-14 09:47
閱讀 4935·2021-09-22 15:52
閱讀 3360·2019-08-30 15:53
閱讀 1454·2019-08-30 15:44
閱讀 679·2019-08-29 16:41
閱讀 1655·2019-08-29 16:28
閱讀 444·2019-08-29 15:23
閱讀 1627·2019-08-26 12:20