【PyQt5-Qt Designer】對話框系列

来源:https://www.cnblogs.com/XJT2018/archive/2019/01/02/10208710.html
-Advertisement-
Play Games

標準輸入對話框(QInputDialog)系列: 主要模塊 效果如下: 完整代碼: 打開文件(QFileDialog)、顏色(QColorDialog)、字體(QFontDialog)對話框 效果如下: 參考: https://zhuanlan.zhihu.com/p/29321561 完整代碼: ...


標準輸入對話框(QInputDialog)系列:

主要模塊

from PyQt5.QtWidgets import QInputDialog

效果如下:

完整代碼:

from PyQt5.QtWidgets import (QApplication, QWidget, QPushButton, QLabel, QInputDialog, QTextBrowser,QGridLayout)
import sys
from PyQt5.QtGui import QIcon


class Example(QWidget):

    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setGeometry(500,500,500,500)
        self.setWindowTitle("標準輸入對話框")
        self.setWindowIcon(QIcon("11.ico"))
        gridLayout = QGridLayout()
        self.lb11 = QLabel("姓名:")
        self.lb12 = QLabel("xiong")
        self.btn1 = QPushButton("修改姓名")
        gridLayout.addWidget(self.lb11,0,0,1,1)
        gridLayout.addWidget(self.lb12,0,1,1,1)
        gridLayout.addWidget(self.btn1,0,2,1,1)
        self.lb21 = QLabel("年齡:")
        self.lb22 = QLabel("25")
        self.btn2 = QPushButton("修改年齡")
        gridLayout.addWidget(self.lb21, 1, 0, 1, 1)
        gridLayout.addWidget(self.lb22, 1, 1, 1, 1)
        gridLayout.addWidget(self.btn2, 1, 2, 1, 1)
        self.lb31 = QLabel("性別:")
        self.lb32 = QLabel("")
        self.btn3 = QPushButton("修改性別")
        gridLayout.addWidget(self.lb31, 2, 0, 1, 1)
        gridLayout.addWidget(self.lb32, 2, 1, 1, 1)
        gridLayout.addWidget(self.btn3, 2, 2, 1, 1)
        self.lb41 = QLabel("身高(cm):")
        self.lb42 = QLabel("177.0")
        self.btn4 = QPushButton("修改身高")
        gridLayout.addWidget(self.lb41, 3, 0, 1, 1)
        gridLayout.addWidget(self.lb42, 3, 1, 1, 1)
        gridLayout.addWidget(self.btn4, 3, 2, 1, 1)
        self.lb51 = QLabel("基本信息:")
        self.textBrowser = QTextBrowser()
        self.btn5 = QPushButton("修改信息")
        gridLayout.addWidget(self.lb51, 4, 0, 1, 1)
        gridLayout.addWidget(self.textBrowser, 5, 0, 1, 3)
        gridLayout.addWidget(self.btn5, 4, 2, 1, 1)

        self.setLayout(gridLayout)

        self.btn1.clicked.connect(self.showDialog)
        self.btn2.clicked.connect(self.showDialog)
        self.btn3.clicked.connect(self.showDialog)
        self.btn4.clicked.connect(self.showDialog)
        self.btn5.clicked.connect(self.showDialog)

    def showDialog(self):
        sender = self.sender()
        if sender == self.btn1:
            text , ok = QInputDialog.getText(self,"修改姓名!","請輸入姓名:")
            if ok:
                self.lb12.setText(text)
        elif sender == self.btn2:
            text, ok = QInputDialog.getInt(self, "修改年齡!", "請輸入年齡:",min=1)
            if ok:
                self.lb22.setText(str(text))
        elif sender == self.btn3:
            text, ok = QInputDialog.getItem(self, "修改性別!", "請輸入性別:",["","","人妖"])
            if ok:
                self.lb32.setText(text)
        elif sender == self.btn4:
            text, ok = QInputDialog.getDouble(self, "修改身高!", "請輸入身高:",min=10.0)
            if ok:
                self.lb42.setText(str(text))
        elif sender == self.btn5:
            text, ok = QInputDialog.getMultiLineText(self, "修改信息!", "請輸入基本信息:")
            if ok:
                self.textBrowser.setText(text)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = Example()
    ex.show()
    sys.exit(app.exec_())

打開文件(QFileDialog)、顏色(QColorDialog)、字體(QFontDialog)對話框

效果如下:

參考:

https://zhuanlan.zhihu.com/p/29321561

完整代碼:

from PyQt5.QtWidgets import (QApplication, QWidget, QPushButton, QColorDialog,QFontDialog,QFileDialog,QGridLayout,QTextEdit)
import sys
from PyQt5.QtGui import QIcon


class Example(QWidget):

    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setGeometry(500,500,400,300)
        self.setWindowTitle("標準輸入對話框")
        self.setWindowIcon(QIcon("11.ico"))
        gridLayout = QGridLayout()
        self.txtFile = QTextEdit()
        self.fileContent = []
        gridLayout.addWidget(self.txtFile,0,0,3,1)
        self.btn1 = QPushButton("打開文件")
        self.btn2 = QPushButton("選擇字體")
        self.btn3 = QPushButton("選擇顏色")
        gridLayout.addWidget(self.btn1, 0, 1, 1, 1)
        gridLayout.addWidget(self.btn2, 1, 1, 1, 1)
        gridLayout.addWidget(self.btn3, 2, 1, 1, 1)
        self.setLayout(gridLayout)

        self.btn1.clicked.connect(self.openFile)
        self.btn2.clicked.connect(self.choseFont)
        self.btn3.clicked.connect(self.choseColor)

    def openFile(self):
        fname = QFileDialog.getOpenFileName(self,"打開文件",'./')
        if fname[0]:
            with open(fname[0],'r+',encoding='utf8',errors="ignore") as f:
                self.fileContent.append(f.read())
                txtCon = "".join(self.fileContent)
                self.txtFile.setText("\n"+txtCon)

    def choseFont(self):
        font , ok = QFontDialog.getFont()
        if ok:
            self.txtFile.setCurrentFont(font)
    def choseColor(self):
        color = QColorDialog.getColor()
        if color.isValid():
            self.txtFile.setTextColor(color)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = Example()
    ex.show()
    sys.exit(app.exec_())

 文件列印(QPageSetupDialog、QPrintDialog)

效果如下:

參考:

https://zhuanlan.zhihu.com/p/29556459

完整代碼:

from PyQt5.QtWidgets import (QApplication, QWidget, QPushButton, QColorDialog,QFontDialog,QFileDialog,QGridLayout,QTextEdit,QDialog)
import sys
from PyQt5.QtGui import QIcon
from PyQt5.QtPrintSupport import QPageSetupDialog,QPrintDialog,QPrinter,QPrintPreviewDialog


class Example(QWidget):

    def __init__(self):
        super().__init__()
        self.initUI()
        self.printer = QPrinter()

    def initUI(self):
        self.setGeometry(500,500,400,300)
        self.setWindowTitle("文件列印對話框")
        self.setWindowIcon(QIcon("11.ico"))
        gridLayout = QGridLayout()
        self.txtFile = QTextEdit()
        self.fileContent = []
        gridLayout.addWidget(self.txtFile,0,0,7,1)
        self.btn1 = QPushButton("打開文件")
        self.btn2 = QPushButton("打開多個文件")
        self.btn3 = QPushButton("選擇字體")
        self.btn4 = QPushButton("選擇顏色")
        self.btn5 = QPushButton("保存文件")
        self.btn6 = QPushButton("頁面設置")
        self.btn7 = QPushButton("列印文件")
        gridLayout.addWidget(self.btn1, 0, 1, 1, 1)
        gridLayout.addWidget(self.btn2, 1, 1, 1, 1)
        gridLayout.addWidget(self.btn3, 2, 1, 1, 1)
        gridLayout.addWidget(self.btn4, 3, 1, 1, 1)
        gridLayout.addWidget(self.btn5, 4, 1, 1, 1)
        gridLayout.addWidget(self.btn6, 5, 1, 1, 1)
        gridLayout.addWidget(self.btn7, 6, 1, 1, 1)
        self.setLayout(gridLayout)

        self.btn1.clicked.connect(self.openFile)
        self.btn2.clicked.connect(self.openFiles)
        self.btn3.clicked.connect(self.choseFont)
        self.btn4.clicked.connect(self.choseColor)
        self.btn5.clicked.connect(self.saveFile)
        self.btn6.clicked.connect(self.pageSet)
        self.btn7.clicked.connect(self.printFile)

    def openFile(self):
        fname = QFileDialog.getOpenFileName(self,"打開文件",'./')
        if fname[0]:
            with open(fname[0],'r+',encoding='utf8',errors="ignore") as f:
                self.fileContent.append(f.read())
                txtCon = "".join(self.fileContent)
                self.txtFile.setText("\n"+txtCon)

    def openFiles(self):
        fnames = QFileDialog.getOpenFileNames(self,"打開多個文件",'./')
        print(fnames)
        if fnames[0]:
            for fname in fnames[0]:
                with open(fname,'r+',encoding='utf8',errors="ignore") as f:
                    self.fileContent.append(f.read()+"\n")
            txtsCon = "".join(self.fileContent)
            self.txtFile.setText(txtsCon)

    def choseFont(self):
        font , ok = QFontDialog.getFont()
        if ok:
            self.txtFile.setCurrentFont(font)

    def choseColor(self):
        color = QColorDialog.getColor()
        if color.isValid():
            self.txtFile.setTextColor(color)

    def saveFile(self):
        fileName = QFileDialog.getSaveFileName(self,"保存文件","./","Text files (*.txt)")
        if fileName[0]:
            with open(fileName[0],'w+',encoding='utf8') as f:
                f.write(self.txtFile.toPlainText())

    def pageSet(self):
        printSetDialog = QPageSetupDialog(self.printer,self)
        printSetDialog.exec_()

    def printFile(self):
        printDialog = QPrintDialog(self.printer,self)
        if QDialog.Accepted == printDialog.exec_():
            self.txtFile.print(self.printer)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = Example()
    ex.show()
    sys.exit(app.exec_())

消息對話框(QMessageBox)

效果如下:

 

 

參考:

https://zhuanlan.zhihu.com/p/29795495

完整代碼:

from PyQt5.QtWidgets import (QApplication, QWidget, QLabel,QPushButton, QMessageBox,QGridLayout,QTextEdit,QCheckBox)
import sys
from PyQt5.QtGui import QIcon,QPixmap


class Example(QWidget):

    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setGeometry(500,500,400,200)
        self.setWindowTitle("標準輸入對話框")
        self.setWindowIcon(QIcon("11.ico"))
        gridLayout = QGridLayout()
        self.lb = QLabel("你選擇了abort!")
        self.btn1 = QPushButton("提示")
        self.btn2 = QPushButton("詢問")
        self.btn3 = QPushButton("警告")
        self.btn4 = QPushButton("錯誤")
        self.btn5 = QPushButton("關於")
        self.btn6 = QPushButton("關於QT")
        gridLayout.addWidget(self.lb,0,0,1,1)
        gridLayout.addWidget(self.btn1,1,0,1,1)
        gridLayout.addWidget(self.btn2,1,1,1,1)
        gridLayout.addWidget(self.btn3,1,2,1,1)
        gridLayout.addWidget(self.btn4,3,0,1,1)
        gridLayout.addWidget(self.btn5,3,1,1,1)
        gridLayout.addWidget(self.btn6,3,2,1,1)
        self.setLayout(gridLayout)

        self.btn1.clicked.connect(self.information_dialog)
        self.btn2.clicked.connect(self.question_dialog)
        self.btn3.clicked.connect(self.warning_dialog)
        self.btn4.clicked.connect(self.critical_dialog)
        self.btn5.clicked.connect(self.about_dialog)
        self.btn6.clicked.connect(self.about_QT_dialog)

    def information_dialog(self):
        reply = QMessageBox.information(self,"提示對話框","這是一個提示對話框", QMessageBox.Ok | QMessageBox.Close, QMessageBox.Close)
        if reply == QMessageBox.Ok:
            self.lb.setText("你選擇了information_dialog的ok!")
        else:
            self.lb.setText("你選擇了information_dialog的close!")

    def question_dialog(self):
        reply = QMessageBox.question(self,"詢問對話框視窗標題!","這是一個詢問對話框。。。",QMessageBox.Yes|QMessageBox.No|QMessageBox.Cancel,QMessageBox.No)
        if reply == QMessageBox.Yes:
            self.lb.setText("你選擇了question_dialog的Yes")
        elif reply == QMessageBox.No:
            self.lb.setText("你選擇了question_dialog的No")
        else:
            self.lb.setText("你選擇了question_dialog的Cancel")

    def warning_dialog(self):
        # reply = QMessageBox.warning(self,'警告','這是一個警告消息對話框', QMessageBox.Save | QMessageBox.Discard | QMessageBox.Cancel, QMessageBox.Save)
        cb = QCheckBox('所有文檔都按此操作')
        msgBox = QMessageBox()
        msgBox.setWindowTitle('警告')
        msgBox.setIcon(QMessageBox.Warning)
        msgBox.setText('這是一個警告消息對話框')
        msgBox.setInformativeText('出現更改願意保存嗎?')
        Save = msgBox.addButton('保存', QMessageBox.AcceptRole)
        NoSave = msgBox.addButton('取消', QMessageBox.RejectRole)
        Cancel = msgBox.addButton('不保存', QMessageBox.DestructiveRole)
        msgBox.setDefaultButton(Save)
        msgBox.setCheckBox(cb)
        cb.stateChanged.connect(self.check)
        reply = msgBox.exec()
        if reply == QMessageBox.AcceptRole:
            self.lb.setText('你選擇了保存!')
        elif reply == QMessageBox.RejectRole:
            self.lb.setText('你選擇了取消!')
        else:
            self.lb.setText('你選擇了不保存!')

    def check(self):
        print(self.sender().isChecked())
        if self.sender().isChecked():
            self.lb.setText('你打勾了哦')
        else:
            self.lb.setText('怎麼又不打了啊')

    def critical_dialog(self):
        # reply = QMessageBox.critical(self,'錯誤','這是一個錯誤消息對話框', QMessageBox.Retry | QMessageBox.Abort | QMessageBox.Ignore , QMessageBox.Retry)
        msgBox = QMessageBox()
        msgBox.setWindowTitle('錯誤')
        msgBox.setIcon(QMessageBox.Critical)
        msgBox.setText("這是一個錯誤消息對話框")
        msgBox.setStandardButtons(QMessageBox.Retry | QMessageBox.Abort | QMessageBox.Ignore)
        msgBox.setDefaultButton(QMessageBox.Retry)
        msgBox.setDetailedText('這是詳細的信息:學點編程吧,我愛你!')
        reply = msgBox.exec()

        if reply == QMessageBox.Retry:
            self.lb.setText('你選擇了Retry!')
        elif reply == QMessageBox.Abort:
            self.lb.setText('你選擇了Abort!')
        else:
            self.lb.setText('你選擇了Ignore!')

    def about_dialog(self):
        # msgBox = QMessageBox.about(self,"關於對話框標題","這是一個關於對話框,是個加拿大小紅旗")
        msgBox = QMessageBox(QMessageBox.NoIcon ,"關於對話框標題","這是一個關於對話框內容...")
        msgBox.setIconPixmap(QPixmap("22.ico"))
        msgBox.exec()

    def about_QT_dialog(self):
        msgBox = QMessageBox.aboutQt(self,"關於QT的對話框標題")

if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = Example()
    ex.show()
    sys.exit(app.exec_())

 3種密碼輸入框的輸入方式

  1. 輸入的密碼不可見;
  2. 輸入的密碼可見,但是滑鼠點擊其他控制項後,密碼不可見;
  3. 輸入的密碼不可見,同時為了更加的安全,屏蔽了滑鼠右鍵、禁用複製、粘貼快捷鍵、滑鼠在密碼框中不可移動,不可全選。就類似我們在輸入QQ密碼的時候一樣。

效果如下:

 

參考:

https://zhuanlan.zhihu.com/p/30152208

完整代碼:

 

進度對話框(QProgressDialog)

效果如下:

參考:

https://zhuanlan.zhihu.com/p/30283367

完整代碼:

from PyQt5.QtWidgets import (QApplication, QWidget, QLabel,QPushButton, QMessageBox,QGridLayout,QLineEdit,QProgressDialog)
import sys
from PyQt5.QtGui import QIcon
from PyQt5.QtCore import Qt


class Example(QWidget):

    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setGeometry(500,500,400,200)
        self.setWindowTitle("進度對話框")
        self.setWindowIcon(QIcon("11.ico"))
        gridLayout = QGridLayout()
        self.lb = QLabel("文件數量")
        self.lineEdit = QLineEdit("100000")
        self.btn = QPushButton("開始")
        gridLayout.addWidget(self.lb,0,0,1,1)
        gridLayout.addWidget(self.lineEdit,0,1,1,3)
        gridLayout.addWidget(self.btn,1,1,1,1)
        self.setLayout(gridLayout)

        self.btn.clicked.connect(self.startProcess)

    def startProcess(self):
        num = int(self.lineEdit.text())
        process = QProgressDialog(self)
        process.setWindowTitle("進度條的進程對話框")
        process.setWindowIcon(QIcon("11.ico"))
        process.setLabelText("正在操作中。。。")
        process.setCancelButtonText("cancel")
        process.setMinimumDuration(3)   #設置進度條的最小持續時間,若進度時間少於3000ms 則不會出現
        process.setWindowModality(Qt.WindowModal)
        process.setRange(0,num)
        for i in range(num):
            process.setValue(i)
            if process.wasCanceled():
                QMessageBox.warning(self,"下載提示","操作失敗")
                break
        else:
            process.setValue(num)
            QMessageBox.information(self,"下載提示","操作成功了")


if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = Example()
    ex.show()
    sys.exit(app.exec_())

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 什麼是閉包 #定義一個函數 def test(number): #在函數內部再定義一個函數,並且這個函數用到了外邊函數的變數,那麼將這個函數以及用到的一些變數稱之為閉包 def test_in(number_in): print("in test_in 函數, number_in is %d"%nu ...
  • 可迭代對象 以直接作用於 for 迴圈的數據類型有以下幾種: 一類是集合數據類型,如 list 、 tuple 、 dict 、 set 、 str 等; 一類是 generator ,包括生成器和帶 yield 的generator function。 這些可以直接作用於 for 迴圈的對象統稱為 ...
  • 運行結果: 結論:非守護線程結束之後jvm退出,守護線程沒有要守護的線程,也進行退出 守護線程和用戶線程唯一的區別在於: 補充說明: 定義:守護線程--也稱“服務線程”,在沒有用戶線程可服務時會自動離開。 優先順序:守護線程的優先順序比較低,用於為系統中的其它對象和線程提供服務。 設置:通過setDae ...
  • 由來: Java是由Sun Microsystems公司於1995年5月推出的Java面向對象程式設計語言和Java平臺的總稱。由James Gosling和同事們共同研發,併在1995年正式推出。 特性: 1.簡單性 :Java吸收了C++語言的各種優點,使得大多數程式員很容易學習和使用。另一方面 ...
  • 1.什麼是進程、線程 進程可以簡單的理解為應用程式。多線程,相當於多個人共同完成一件事情,每個線程,獨立完成一件任務。因此,一個進程至少有一個線程,一個線程不能獨立存在,它必須是進程的一部分。 進程:每個獨立運行著的程式。具有獨立的記憶體空間和系統資源。(建大廈) 線程:是一個進程內部的一條執行路徑。 ...
  • 在軟體開發領域中,人們經常會用到這一個概念——“設計模式”(design pattern),它是一種針對軟體設計的共性問題而提出的解決方案。在一本聖經級的書籍《設計模式:可復用面向對象軟體的基礎》(1991年,Design Patterns - Elements of Reusable Object ...
  • `synchronized java 同步`的關鍵字,其典型的作用域如下所示. 1 對象鎖 1.1 代碼塊修飾(對象) 此時, 用於保證 函數中的被 大括弧包裹的代碼同步執行. 作用的對象為 的對象實例,例如 函數中的 以及 . Tips: 1. 若在多個線程中被調用,其輸出順序將保證同步,按照 的 ...
  • Django 為大家提供了一個完善的後臺管理系統—admin,但是這個後臺管理系統總體來說不太適合國人的習慣,所以有大神就使用 bootstrap 和 jQuery,為我們開發了一個第三 方的 Django 後臺管理系統—xadmin,這個界面的友好度比較高,目前企業的使用頻率比較高,我們來學習一些 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...