溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PyQt5快速入門(七)PyQt5擴展

發(fā)布時間:2020-07-06 20:15:05 來源:網絡 閱讀:1551 作者:天山老妖S 欄目:編程語言

PyQt5快速入門(七)PyQt5擴展

一、PyQt5項目發(fā)布

1、PyInstaller簡介

PyInstaller是一款免費易用的打包工具,支持Windows、Linux、MacOS,并且支持32位和64位系統(tǒng)。
http://www.pyinstaller.org/
PyInstaller安裝:
pip install pyinstaller

2、PyInstaller使用

PyInstaller使用命令如下:
pyinstaller yourprogram.py
PyInstaller使用時需切換至xxx.py文件所在目錄下。
常用可選項如下:
-F:打包后只生成單個可執(zhí)行文件
-D:默認選項,創(chuàng)建一個目錄,包含可執(zhí)行文件以及大量依賴文件
-c:默認選項,使用控制臺
-w:不使用控制臺
-p:添加搜索路徑,讓其找到對應的庫
-i:改變生成程序的icon圖標。

3、PyInstaller原理

PyInstaller將Python解釋器和Python腳本打包成一個可執(zhí)行文件,并沒有編譯為機器碼。PyInstaller打包的可執(zhí)行文件不會提高運行效率,而且可能會降低運行效率。打包的優(yōu)勢是在運行機器上不用安裝Python和Python腳本所依賴的庫。在Linux系統(tǒng)下,PyInstaller主要使用binutil工具包中的ldd和objdump命令。
PyInstaller會分析指定的Python腳本所依賴的其它依賴,然后進行查找和復制,把所有的依賴都收集起來并進行加密處理,包括Python解釋器,最后將文件打包到一個目錄或打包到可執(zhí)行文件中。
使用PyInstaller打包生成的可執(zhí)行文件,只能在和打包機器相同的環(huán)境下運行,如果要在不同的操作系統(tǒng)上運行,必須在新的操作系統(tǒng)環(huán)境上重新打包。

二、網頁交互

1、QWebEngineView簡介

PyQt5使用QWebEngineView來展示HTML頁面,WebEngine是基于谷歌Chromium引擎開發(fā)的,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>
                              <h2>hello PyQt5</h2>
                              <h3>hello PyQt5<h3>
                           </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代碼的解耦,便于開發(fā)人員進行分工協(xié)作,

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  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__":
    # 創(chuàng)建一個 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傳遞的數據,經過業(yè)務處理后,把處理過后的數據返回給Web頁面。
(1)創(chuàng)建QWebChannel對象
創(chuàng)建QWebChannel對象,注冊一個需要橋接的對象,以便Web頁面的JavaScript使用。
channel = QWebChannel()
obj = ClassName()
channel.registerObject("bridge", obj)
view.page().setWebChannel(channel)
(2)創(chuàng)建共享數據的PyQt對象
創(chuàng)建的共享對象需要繼承自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)

    # 需要定義對外發(fā)布的方法
    strValue = pyqtProperty(str, fget=_g
```etStrValue, fset=_setStrValue)

(3)創(chuàng)建調用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);
});

});

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI