PyQt5快速入门(七)PyQt5扩展

PyQt5快速入门(七)PyQt5扩展

一、PyQt5项目发布

1、PyInstaller简介

PyInstaller是一款免费易用的打包工具,支持Windows、Linux、MacOS,并且支持32位和64位系统。
http://www.pyinstaller.org/
PyInstaller安装:
pip install pyinstaller

2、PyInstaller使用

PyInstaller使用命令如下:
pyinstaller yourprogram.py
PyInstaller使用时需切换至xxx.py文件所在目录下。
常用可选项如下:
-F:打包后只生成单个可执行文件
-D:默认选项,创建一个目录,包含可执行文件以及大量依赖文件
-c:默认选项,使用控制台
-w:不使用控制台
-p:添加搜索路径,让其找到对应的库
-i:改变生成程序的icon图标。

3、PyInstaller原理

PyInstaller将Python解释器和Python脚本打包成一个可执行文件,并没有编译为机器码。PyInstaller打包的可执行文件不会提高运行效率,而且可能会降低运行效率。打包的优势是在运行机器上不用安装Python和Python脚本所依赖的库。在Linux系统下,PyInstaller主要使用binutil工具包中的ldd和objdump命令。
PyInstaller会分析指定的Python脚本所依赖的其它依赖,然后进行查找和复制,把所有的依赖都收集起来并进行加密处理,包括Python解释器,最后将文件打包到一个目录或打包到可执行文件中。
使用PyInstaller打包生成的可执行文件,只能在和打包机器相同的环境下运行,如果要在不同的操作系统上运行,必须在新的操作系统环境上重新打包。

二、网页交互

1、QWebEngineView简介

PyQt5使用QWebEngineView来展示HTML页面,WebEngine是基于谷歌Chromium引擎开发的,PyQt5中可以使用PyQt5.QtWebKitWidgets.QWebEngineView来使用网页控件。
QWebEngineView使用load(QUrl url)加载指定的URL定显示,setHtml(QString &html)用于将网页视图的内容设置为指定的HTML内容。
QWebEngineView使用load加载一个Web页面,实际是使用HTTP GET方法加载Web页面。

2、加载显示外部Web页面

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
from PyQt5.QtWebEngineWidgets import *

class MainWindow(QWidget):

    def __init__(self, parent=None):
        super().__init__(parent)
        self.layout = QVBoxLayout()
        self.browser = self.browser = QWebEngineView()
        self.layout.addWidget(self.browser)
        self.setLayout(self.layout)
        self.browser.load(QUrl("http://www.51cto.com/"))

        self.setWindowTitle("HuaWei Web")
        self.setGeometry(5, 30, 1355, 730)

if __name__ == "__main__":
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()

    sys.exit(app.exec_())

3、加载本地Web页面

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
from PyQt5.QtWebEngineWidgets import *

class MainWindow(QWidget):

    def __init__(self, parent=None):
        super().__init__(parent)
        self.layout = QVBoxLayout()
        self.browser = self.browser = QWebEngineView()
        self.layout.addWidget(self.browser)
        self.setLayout(self.layout)
        self.browser.load(QUrl(r"/home/user/PyQt.html"))

        self.setWindowTitle("Local HTML")
        self.setGeometry(5, 30, 1355, 730)

if __name__ == "__main__":
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()

    sys.exit(app.exec_())

4、加载并显示嵌入的HTML代码

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
from PyQt5.QtWebEngineWidgets import *

class MainWindow(QWidget):

    def __init__(self, parent=None):
        super().__init__(parent)
        self.layout = QVBoxLayout()
        self.browser = self.browser = QWebEngineView()
        self.layout.addWidget(self.browser)
        self.setLayout(self.layout)
        self.browser.setHtml(‘‘‘
                            <!DOCTYPE html>
                            <html>
                            <head>
                           <meta charset="UTF-8">
                           <title>PyQt5</title>
                            </head>
                           <body>
                              <h1>hello PyQt5</h1>
                              <h2>hello PyQt5<h2>
                           </body>
                            </html>
                            ‘‘‘)

        self.setWindowTitle("Local HTML")
        self.setGeometry(5, 30, 1355, 730)

if __name__ == "__main__":
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()

    sys.exit(app.exec_())

5、PyQt5调用JavaScript代码

通过QWebEnginePage的runJavaScript(str, callable)可以方便地实现PyQt5和HTMP/JavaScript的双向通信,实现了Python代码和HTMP/JavaScript代码的解耦,便于开发人员进行分工协作,

from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QPushButton
from PyQt5.QtWebEngineWidgets import QWebEngineView
import sys

html = ‘‘‘
      <html>
        <head>
          <title>A Demo Page</title>
          <script language="javascript">
            // Completes the full-name control and
            // shows the submit button
            function completeAndReturnName() {
              var fname = document.getElementById(‘fname‘).value;
              var lname = document.getElementById(‘lname‘).value;
              var full = fname + ‘ ‘ + lname;
              document.getElementById(‘fullname‘).value = full;
              document.getElementById(‘submit-btn‘).style.display = ‘block‘;
              return full;
            }
          </script>
        </head>
        <body>
          <form>
            <label for="fname">First name:</label>
            <input type="text" name="fname" id="fname"></input>
            <br />
            <label for="lname">Last name:</label>
            <input type="text" name="lname" id="lname"></input>
            <br />
            <label for="fullname">Full name:</label>
            <input disabled type="text" name="fullname" id="fullname"></input>
            <br />
            <input style="display: none;" type="submit" id="submit-btn"></input>
          </form>
        </body>
      </html>
    ‘‘‘

class MainWindow(QWidget):
    def __init__(self,parent=None):
        super(MainWindow, self).__init__(parent)
        self.result = None
        self.layout = QVBoxLayout()
        self.webView = QWebEngineView()
        self.webView.setHtml(html)
        self.layout.addWidget(self.webView)
        button = QPushButton(‘设置全名‘)
        self.layout.addWidget(button)
        self.setLayout(self.layout)
        self.resize(400, 200)
        self.setWindowTitle("PyQt JS")
        button.clicked.connect(self.complete_name)

    def complete_name(self):
        self.webView.page().runJavaScript(‘completeAndReturnName();‘, self.js_callback)

    def js_callback(self, result):
        self.result = result
        print(result)

if __name__ == "__main__":
    # 创建一个 application实例
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()
    sys.exit(app.exec_())

6、JavaScript调用PyQt5代码

JavaScript调用PyQt代码是指PyQt可以与加载的Web页面进行双向的数据交互。首先,使用QWebEngineView对象加载Web页面后可以获得页面中表单输入数据,在Web页面中通过JavaScript代码收集用户提交的数据。然后,在Web页面中,JavaScript通过桥连接方式传递数据给PyQt。PyQt接收到Web传递的数据,经过业务处理后,把处理过后的数据返回给Web页面。
(1)创建QWebChannel对象
创建QWebChannel对象,注册一个需要桥接的对象,以便Web页面的JavaScript使用。
channel = QWebChannel()
obj = ClassName()
channel.registerObject("bridge", obj)
view.page().setWebChannel(channel)
(2)创建共享数据的PyQt对象
创建的共享对象需要继承自QWidget或QObject。

from PyQt5.QtCore import QObject
from PyQt5.QtCore import pyqtProperty
from PyQt5.QtWidgets import QWidget, QMessageBox

class SharedObject(QWidget):

    def __init__(self):
        super(SharedObject, self).__init__()

    def _getStrValue(self):
        #
        return ‘100‘

    def _setStrValue(self, str):
        # get web parameter
        print("web parameter: ", str)

    # 需要定义对外发布的方法
    strValue = pyqtProperty(str, fget=_g
```etStrValue, fset=_setStrValue)

(3)创建调用PyQt的Web页面
在Web页面访问PyQt中注册的对象,获得channel.objects.bridge共享对象,bridge是在PyQt中注册共享对象时指定的名称,核心代码如下:

document.addEventListener("DOMContentLoaded", function()
{

new QWebChannel(qt.webChannelTransport, function(channel){
    window.bridge = channel.objects.bridge;
    alert(‘bridge=‘ + bridge + ‘\n从pyqt传来的参数=‘ + window.bridge.strValue);
});

});

原文地址:https://blog.51cto.com/9291927/2424319

时间: 2024-10-09 18:38:05

PyQt5快速入门(七)PyQt5扩展的相关文章

PyQt5快速入门(三)PyQt5基本窗口组件

PyQt5快速入门(三)PyQt5基本窗口组件 一.QMainWindow 1.窗口类型简介 QMainWindow.QWidget.QDialog用于创建窗口,可以直接使用,也可以派生使用.QMainWindow窗口包含菜单栏.工具栏.状态栏.标题栏等,是最常见的窗口形式.QDialog是对话框窗口的基类,主要用于执行短期任务,或与用户进行交互,可以是模态或非模态的.QDialog对话框没有菜单栏.工具栏.状态栏等.QWidget是Qt图形组件的基类,可以作为顶层窗口,也可以嵌入到其它组件中.

PyQt5快速入门(一)PyQt5简介

PyQt5快速入门(一)PyQt5简介 一.PyQt5简介 1.PyQt5简介 PyQt是Qt框架的Python语言实现,由Riverbank Computing开发,是最强大的GUI库之一.PyQt提供了一个设计良好的窗口控件集合,每一个PyQt控件都对应一个Qt控件,因此PyQt的API接口与Qt的API接口很接近,但PyQt不再使用QMake系统和Q_OBJECT宏.官方网站:www.riverbankcomputing.comPyQt5提供GPL版和商业版证书,自由开发者可以使用免费的G

PyQt5快速入门(四)PyQt5高级窗口组件

PyQt5快速入门(四)PyQt5高级窗口组件 一.QTableView 1.QTableView简介 QTableView可以使用自定义的数据模型来显示内容,通过setModel绑定数据源,由QAbstractItemView类定义的接口来实现,使其能够显示由QAbstractItemModel类派生的模型提供的数据. 2.标准模型 QStringListModel 字符串链表数据模型QStandardItemModel标准数据项模型,存储任意结构层次的数据QDirModel 文件系统目录模型

PyQt5快速入门(二)PyQt5信号槽机制

PyQt5快速入门(二)PyQt5信号槽机制 一.信号槽机制简介 1.信号槽简介 信号槽是Qt的核心机制,也是PyQt编程中对象进行通信的机制.在Qt中,QObject对象和PyQt中所有继承自QWidget的控件都支持信号槽机制.当信号发射时,连接的槽函数会自动执行.在PyQt5中,信号与槽函数通过object.signal.connect()方法进行连接.信号槽特点如下:(1)一个信号可以连接多个槽(2)一个信号可以连接另一个信号(3)信号参数可以是任意Python类型(4)一个槽可以监听多

PyQt5快速入门

PyQt5快速入门系列博客根据<PyQt5快速开发与实战>学习而来,请参考原书.PyQt5快速入门(一)PyQt5简介https://blog.51cto.com/9291927/2422184PyQt5快速入门(二)PyQt5信号槽机制https://blog.51cto.com/9291927/2422187 原文地址:https://blog.51cto.com/9291927/2422188

mybatis快速入门(七)-spring-mybatis整合

今天写写spring-mybatis整合吧,先写个原始dao类的整合,下一节在写个动态代理的整合,我就不写太详细了,因为前面的章节基本上都有了,我直接就一口气都写出来需要那些文件然后在直接贴代码,首先创建一个java项目,. 首先导入jar包,jar地址下载 目录结构 1.db.properties数据连接池 jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/mybatis jdbc.username=r

Linux快速入门04-扩展知识

这部分是快速学习的最后一部分知识,其中最重要的内容就是源码的打包和软件的安装的学习,由于个人的Linux学习目的就是自己能在阿里云Ubuntu上搭建一个简单的nodejs发布环境. Linux系列文章 快速入门系列--Linux--01基础概念 快速入门系列--Linux--02文件系统管理 快速入门系列--Linux--03系统管理 快速入门系列--Linux--04扩展知识 由于现在均是使用云平台,这部分内容已完全透明,因而只做一个简单的了解,整个linux的启动过程包含如下8个步骤: 1.

区块链快速入门(七)——比特币

区块链快速入门(七)--比特币 一.比特币简介 比特币(BitCoin,BTC)是基于区块链技术的一种数字货币实现,比特币网络是历史上首个经过大规模长时间检验的数字货币系统.自2009 年正式上线以来,比特币价格经历了数次的震荡,目前每枚比特币市场价格超过6000 美金,并曾经一度接近20000美金.比特币网络在功能上具有如下特点:A.去中心化没有任何独立个体可以对网络中交易进行破坏,任何交易请求都需要大多数参与者的共识.B.匿名性比特币网络中账户地址是匿名的,无法从交易信息关联到具体的个体,但

快速入门git第七步

2.7 Git 基础 - 技巧和窍门技巧和窍门在结束本章之前,我还想和大家分享一些 Git 使用的技巧和窍门.很多使用 Git 的开发者可能根本就没用过这些技巧,我们也不是说在读过本书后非得用这些技巧不可,但至少应该有所了解吧.说实话,有了这些小窍门,我们的工作可以变得更简单,更轻松,更高效. 自动补全如果你用的是 Bash shell,可以试试看 Git 提供的自动补全脚本.下载 Git 的源代码,进入 contrib/completion 目录,会看到一个 git-completion.ba