pyqt5加载chrome浏览器(PyQt5内嵌浏览器注入JavaScript脚本实现自动化操作的代码实例)
类别:脚本大全 浏览量:142
时间:2022-03-29 03:05:12 pyqt5加载chrome浏览器
PyQt5内嵌浏览器注入JavaScript脚本实现自动化操作的代码实例概要
应同学邀请,演示如何使用 PyQt5 内嵌浏览器浏览网页,并注入 Javascript 脚本实现自动化操作。
下面测试的是一个廉价机票预订网站(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); } |
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对开心学习网的支持。如果你想了解更多相关内容请查看下面相关链接
原文链接:https://segmentfault.com/a/1190000016222966
您可能感兴趣
- pyqt5 登录界面(pyqt5利用pyqtDesigner实现登录界面)
- pyqt5实例讲解(PyQt5实现简易计算器)
- pyqt一键部署python环境(python使用PyQt5的简单方法)
- pyqt5对话框(Pyqt5如何让QMessageBox按钮显示中文示例代码)
- pyqt5界面绘图(PyQt5的PyQtGraph实践系列3之实时数据更新绘制图形)
- pyqt5数据模型(PyQt5实现简单数据标注工具)
- pyqt5怎么在pycharm中安装(pycharm+PyQt5+python最新开发环境配置踩坑)
- pyqt5代码实例(pyqt5实现登录界面的模板)
- python实例之pyqt5多窗口实现(python+pyqt5编写md5生成器)
- pyqt5信号槽编辑器(浅谈pyqt5中信号与槽的认识)
- python简单代码画图(python+pyqt5实现图片批量缩放工具)
- pyqt5加载chrome浏览器(PyQt5内嵌浏览器注入JavaScript脚本实现自动化操作的代码实例)
- python串口怎么使用(使用Python3+PyQT5+Pyserial 实现简单的串口工具方法)
- python pyqt 教程(Python+PyQt5实现美剧爬虫可视工具的方法)
- python用pyqt5制作登录界面(python3+pyqt5+itchat微信定时发送消息的方法)
- 小说 小伙穿越成刘备,用现代知识指挥作战,众谋士都看呆了(小伙穿越成刘备)
- 解析葡萄牙6-1瑞士 进攻多点开花,贡萨洛-拉莫斯一战成名(解析葡萄牙6-1瑞士)
- 这支 奇兵队 腕大 有范儿还各怀绝技,毒贩杀人犯见了都要仓皇而逃(这支奇兵队腕大)
- 雄藩崛起 奇兵队与幕末长州藩军事改革(雄藩崛起奇兵队与幕末长州藩军事改革)
- 九月初,爱如蜜糖,甜到心扉,迷恋彼此,一日不见兮,思之若狂(九月初爱如蜜糖)
- ()
热门推荐
- asp.net lambda表达式
- docker如何进入容器中(修改已有docker容器中的内容方法)
- apache和yii域名配置(yii框架数据库关联查询操作示例)
- python合并多个excel可以刷新吗(python 实现读取一个excel多个sheet表并合并的方法)
- nginx 怎么避免options请求(详解nginx 的 default_server 定义及匹配规则)
- python函数式编程源码(python仿evething的文件搜索器实例代码)
- docker测试环境搭建(docker环境搭建JMeter+Grafana+influxdb可视化性能监控平台的教程)
- web接口测试中需要测试的几个点
- 怎么开放sql server端口(SQLServer2019配置端口号的实现)
- python如何将xls转成xlsx(Python这样操作能存储100多万行的xlsx文件)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9