➣ Reading Time: 7 minutes

看完這篇文章你會得到的成果圖

這次是我初學 PyQt5 的一些筆記,
每天都學一點點,至於整理的部分就慢慢一個個來
畢竟知道 PyQt5 有很多東西XD

此篇文章的範例程式碼 github

https://github.com/howarder3/ironman2021_PyQt5_photoshop/tree/main/day01_install_and_hello

安裝

先安裝 PyQt5

新的方法 (之後到 OpenCV 章節時,可避免一些問題):

建議使用 conda 的方式安裝,

打開終端機的對應 conda 環境輸入

conda install pyqt 

舊的方法 (之後可能會有些問題)

打開終端機輸入

pip install PyQt5

至於前面步驟「可能」還有:

  • 安裝 python
  • 安裝 anaconda (optional,看你想不想要管理 python 環境)

這部分就先不多說明,網路已經很多好文章了!

範例程式碼

PyQt5 可以學習的東西太多了! 我一開始學也是超級混亂的!!!
所以我們慢慢來!
先什麼都不管,直接跑程式碼,至少我們要確認「有沒有安裝成功」!

複製以下程式碼,直接跑就對了

應該要「能正常執行」,不然就是你沒安裝成功 PyQt5

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QLabel
from PyQt5.QtGui import QIcon
from PyQt5.QtCore import pyqtSlot

def window():
   app = QApplication(sys.argv)
   widget = QWidget()

   textLabel = QLabel(widget)
   textLabel.setText("Hello World!")
   textLabel.move(110,85)

   widget.setGeometry(50,50,320,200)
   widget.setWindowTitle("PyQt5 Example")
   widget.show()
   sys.exit(app.exec_())

if __name__ == '__main__':
   window()

執行

到這邊相信大家都懂了XD,就一如往常的執行這份 python 吧!
(檔名請自行更換)

python hello.py

結果

  • windows 版本

不論是任何版本,複製上面程式碼應該都要看到這個結果,
不然請再去檢查你的 PyQt5 為何沒有安裝成功!
(沒安裝成功的原因太多種了,這邊很難細述)

說明

之後還會有更詳細的說明,但是既然這邊都提到了還是要交代一下!

如果想看更詳細的說明,這邊可以先跳過,日後文章會再來細講

建立一個視窗應用,並且宣告一個 QWidget 物件

這邊基本上寫法不太會改

  • app 代表「系統」的視窗程式,
  • widger 代表一個 QWidget() 的物件 (我們開發的視窗)
app = QApplication(sys.argv)
widget = QWidget()

在 widget 新增一個文字物件

這邊我們使用的是 QLabel,之後會在細講這東西,
我們將這東西存入 textLabel 這個變數中,並且作了文字與位置的設定

textLabel = QLabel(widget)
textLabel.setText("Hello World!")
textLabel.move(110,85)

在 widget 設定視窗大小,設定標題名稱,並顯示於畫面上

這邊就是如何設定我們的 QWidget 視窗,

  • setGeometry 可以決定視窗大小
  • setWindowTitle 可以決定視窗名稱
  • show 將視窗顯示
widget.setGeometry(50,50,320,200)
widget.setWindowTitle("PyQt5 Example")
widget.show()

結束視窗應用

這邊是在偵測使用者呼叫的視窗是否有被關閉,
就是我們一般視窗「右上角(windows) 的叉叉」,偵測到關閉程式後,
讓程式順利結束運行,如果沒有這行就等於程式直接結束,
也不會等使用者把視窗關閉XD

sys.exit(app.exec_())

小結

到這邊,看起來很簡單(嗎?),不過這就是我們初探 PyQt5 的第一步囉!
(到這邊,距離大致掌握 PyQt5 還好遙遠… 太多東西要學了)

Reference

⭐Python PyQt5 相關文章整理⭐:
⭐基礎知識與架構篇⭐:
1.【PyQt5】Day 1 – 安裝 PyQt,建立自己的第一支 PyQt5 程式
2.【PyQt5】Day 2 – 利用 Qt designer 建立第一支有自己介面的 PyQt5 程式
3.【PyQt5】Day 4 – 重要的 Qt 程式邏輯觀念,務必先有此觀念後面才會懂自己在幹嘛
4.【PyQt5】Day 5 – 開始來設計我們的 controller.py,改以「程式角度」來說明如何建立 PyQt 的系統
⭐基本介面控制篇⭐:
1.【PyQt5】Day 6 – 我們的第一個 output 手段 – Qlabel
2.【PyQt5】Day 7 – 我們的第一個 input 手段 – QPushButton
3.【PyQt5】Day 8 – 我們的第二個 input 手段 – QLineEdit
4.【PyQt5】Day 9 – 以 QLineEdit, QTextEdit, QPlainTextEdit 作為文字的輸入
5.【PyQt5】Day 10 – 以 QFileDialog 讀取系統的檔案、資料夾
⭐影像處理篇⭐:
1.【PyQt5】Day 11 – 以 Qlabel 在 PyQt 中顯示圖片 (基於 QImage 使用 OpenCV)
2.【PyQt5】Day 12 – 建立一個可以縮放圖片大小的顯示器 (基於 QImage 使用 OpenCV)
3.【PyQt5】Day 13 – 使用 QVBoxLayout, QscrollArea 製作出捲軸,以高解析度檢視圖片 (基於 QImage 使用 OpenCV)
⭐打包程式篇⭐:
1.【PyQt5】Day 3 – 用 pyinstaller 將 python 程式打包,把每天的成果分享給你的親朋好友
⭐【喜歡我的文章嗎? 歡迎幫我按讚~ 讓基金會請創作者喝一杯咖啡!
如果喜歡我的文章,請幫我在下方【按五下Like】 (Google, Facebook 免註冊),會由 「LikeCoin」 贊助作者鼓勵繼續創作,讀者們「只需幫忙按讚,完全不用出錢」哦!

likecoin-steps