博客說明python
文章所涉及的資料來自互聯網整理和我的總結,意在於我的學習和經驗彙總,若有什麼地方侵權,請聯繫本人刪除,謝謝!
首先咱們須要的是咱們的開發環境,我使用的是python 3.8.2和pyqt 5.14.2,由於有強迫症,因此喜歡使用最新版的git
這是新版使用的web瀏覽器引擎,更加的貼近谷歌瀏覽器,好像是須要單獨安裝,我就是這樣的github
pip3 install QtWebEngineWidgets
作這個的時候遇到好多坑,好比在多個tab裏面打開頁面,要使用這個QTabWidget,這個不用咱們再去下載了,已經集成了web
這個搞了我半天,我以前還一直覺得是跨域的問題,實際上是這個機制的問題,須要重寫createWindow方法跨域
# 建立瀏覽器,重寫重寫createwindow方法實現頁面鏈接的點擊跳轉 class WebEngineView(QWebEngineView): def __init__(self, mainwindow, parent=None): super(WebEngineView, self).__init__(parent) self.mainwindow = mainwindow # 重寫createwindow() def createWindow(self, QWebEnginePage_WebWindowType): new_webview = WebEngineView(self.mainwindow) self.mainwindow.create_tab(new_webview) return new_webview
而後大致就是一些頁面的佈局,這個可使用Qt Designer,能夠自動轉化成爲咱們的py代碼瀏覽器
而後就是一些前進,後退,刷新,中止的方法網絡
# -*- coding: utf-8 -*- # @Author: dshj # @Date : 2020/04/26 import sys from PyQt5.QtWidgets import * from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWebEngineWidgets import QWebEngineView # 建立主窗口 class MainWindow(QMainWindow): def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) # 設置窗口標題 self.setWindowTitle('簡易瀏覽器') # 設置窗口大小900*600 self.resize(1300, 700) self.show() # 建立tabwidget(多標籤頁面) self.tabWidget = QTabWidget() self.tabWidget.setTabShape(QTabWidget.Triangular) self.tabWidget.setDocumentMode(True) self.tabWidget.setMovable(True) self.tabWidget.setTabsClosable(True) self.tabWidget.tabCloseRequested.connect(self.close_Tab) self.setCentralWidget(self.tabWidget) # 第一個tab頁面 self.webview = WebEngineView(self) # self必需要有,是將主窗口做爲參數,傳給瀏覽器 self.webview.load(QUrl("http://www.baidu.com")) self.create_tab(self.webview) # 使用QToolBar建立導航欄,並使用QAction建立按鈕 # 添加導航欄 navigation_bar = QToolBar('Navigation') # 設定圖標的大小 navigation_bar.setIconSize(QSize(16, 16)) # 添加導航欄到窗口中 self.addToolBar(navigation_bar) # QAction類提供了抽象的用戶界面action,這些action能夠被放置在窗口部件中 # 添加前進、後退、中止加載和刷新的按鈕 back_button = QAction(QIcon('icons/houtui.png'), 'Back', self) next_button = QAction(QIcon('icons/qianjin.png'), 'Forward', self) stop_button = QAction(QIcon('icons/close.png'), 'stop', self) reload_button = QAction(QIcon('icons/shuaxin.png'), 'reload', self) # 綁定事件 back_button.triggered.connect(self.webview.back) next_button.triggered.connect(self.webview.forward) stop_button.triggered.connect(self.webview.stop) reload_button.triggered.connect(self.webview.reload) # 將按鈕添加到導航欄上 navigation_bar.addAction(back_button) navigation_bar.addAction(next_button) navigation_bar.addAction(stop_button) navigation_bar.addAction(reload_button) # 添加URL地址欄 self.urlbar = QLineEdit() # 讓地址欄能響應回車按鍵信號 self.urlbar.returnPressed.connect(self.navigate_to_url) navigation_bar.addSeparator() navigation_bar.addWidget(self.urlbar) # 讓瀏覽器相應url地址的變化 self.webview.urlChanged.connect(self.renew_urlbar) # 顯示地址 def navigate_to_url(self): q = QUrl(self.urlbar.text()) if q.scheme() == '': q.setScheme('http') self.webview.setUrl(q) # 響應輸入的地址 def renew_urlbar(self, q): # 將當前網頁的連接更新到地址欄 self.urlbar.setText(q.toString()) self.urlbar.setCursorPosition(0) # 建立tab頁面 def create_tab(self, webview): self.tab = QWidget() self.tabWidget.addTab(self.tab, "新建頁面") self.tabWidget.setCurrentWidget(self.tab) # 渲染到頁面 self.Layout = QHBoxLayout(self.tab) self.Layout.setContentsMargins(0, 0, 0, 0) self.Layout.addWidget(webview) # 關閉tab頁面 def close_Tab(self, index): if self.tabWidget.count() > 1: self.tabWidget.removeTab(index) else: self.close() # 當只有1個tab時,關閉主窗口 # 建立瀏覽器,重寫重寫createwindow方法實現頁面鏈接的點擊跳轉 class WebEngineView(QWebEngineView): def __init__(self, mainwindow, parent=None): super(WebEngineView, self).__init__(parent) self.mainwindow = mainwindow # 重寫createwindow() def createWindow(self, QWebEnginePage_WebWindowType): new_webview = WebEngineView(self.mainwindow) self.mainwindow.create_tab(new_webview) return new_webview # 程序入口 if __name__ == "__main__": app = QApplication(sys.argv) # 建立主窗口 browser = MainWindow() browser.show() # 運行應用,並監聽事件 sys.exit(app.exec_())
能夠去點擊地址去嘗試app
圖標什麼的能夠在阿里巴巴矢量圖標庫裏面去找到佈局
貼一下github地址學習
https://github.com/Tangleia/Python-tools-borwser
感謝
萬能的網絡以及勤勞的本身