[Python實戰]你也能寫的計時器程序

請關注公眾號:Python高效編程,發送計時器,便會得到相應的下載地址。

上次,公眾號介紹瞭如何 ,並介紹瞭如何在 Pycharm 中使用 Qt Designer 生成 UI 文件。這次,我們要學習如何寫一個簡單的計時器程序。

[Python實戰]你也能寫的計時器程序

圖形界面

首先,我們使用 Qt Designer 來設計計時器的圖形界面,參考如下:

左邊畫三個按鈕,分別命名為:開始、暫停、清零。右邊畫一個標籤,文本內容為空。當然,你也可以直接導入我提供的 Ui_timer.py 文件,然後編寫其他部分代碼。

[Python實戰]你也能寫的計時器程序

[Python實戰]你也能寫的計時器程序

QTimer 介紹

QTimer 類提供了一次性和可供重複使用的定時器。要使用這個接口,我們首先要創建一個 QTimer 對象,並將 timeout 信號綁定到指定的函數上,接著調用QTimer 對象的 start 方法。這樣,定時器就會以你設定的時間間隔恆定地發出 timeout 信號。

QTimer.start(ms) 方法,用於啟動或重啟計時器,ms 參數是時間間隔,單位是毫秒。QTimer.timeout.connect(method) 將定時器與方法綁定,當超過定時器設定的時間,就會調用該方法。

示例:

from PyQt5.QtCore import QTimer
# 實例化定時器
self.timer = QTimer(self)
# start(10) 將時間間隔設定為 10 毫秒
# 每過 10 毫秒,就會調用一次 self.MyFunc 方法
self.timer.timeout.connect(self.MyFunc)
self.timer.start(10)
[Python實戰]你也能寫的計時器程序

核心模塊

下面是總體的代碼結構,包括類的屬性及方法:

[Python實戰]你也能寫的計時器程序

showTime 是之前提到的 QTimer.timeout.connect 函數所綁定的方法,只要定時器超時,就會調用這個函數。這個函數的作用是顯示計時器的時間。

計時器的時間公式:當前時間 - 初始時間 - 暫停時間,這裡關鍵的一步就是要計算暫停時間。所以,我們還需要兩個類屬性 self._pause_time 和 self._restart_time,分別表示暫停計時器那一刻的時間和再次啟動計時器那一刻的時間,兩個時間相減就得到總共暫停的時間。每當計時器暫停一次,self._pause_total 屬性就要加上新的暫停時間。

def showTime(self):
# 如果暫停標誌為真,self._pause_total 屬性要加上暫停時間
# 並設置暫停標誌為假
if self._pause_flag:
self._pause_total += self._restart_time
- self._pause_time
self._pause_flag = False
# 計算運行時間
run_time = self._current_time - self._pause_total
- self._start_time
# 將時間轉換為文本
text = convert(run_time)
# 標籤顯示文字
self.label.setText(text)

convert 函數,為自定義的函數,把得到的單位為秒的時間轉換成小時、分鐘和秒三個部分,並返回格式化的字符串。int 充當向下取整的作用,注意這裡不能使用 round 或者 math.ceil 等向上取整的函數,否則會出現兩次 60 秒。

# 將時間表示為小時、分鐘、秒的形式
# 返回格式化字符串
def convert(raw_time):
hour = int(raw_time // 3600)
minute = int((raw_time % 3600) // 60)
second = int(raw_time % 60)
fmt = '{:0>2d}:{:0>2d}:{:0>2d}'
return fmt.format(hour, minute, second)

下面是三個按鈕分別綁定的函數。

開始按鈕綁定 startTimer 函數, self._current_time 相當於 time.time() 也就是當前時間。如果第一次啟動或者清零後的啟動,就要初始化計時器啟動時間 self._start_time。如果是暫停後的啟動,就要更新 計時器重啟時間 self._restart_time。之後,設置按鈕的狀態。

暫停按鈕綁定 pauseTimer 函數。這個函數主要負責更新self._pause_flag,並記錄暫停計時器這一刻的時間,並停止向定時器發送信號。也就說,這時就不再執行函數 showTime。最後,設置按鈕狀態。

清零按鈕負責恢復至初始狀態。

def startTimer(self):
# 發出計時信號
self.timer.start(0)
# 如果 self._pause_flag 為假,更新開始時間
# 否則,更新重啟時間
if not self._pause_flag:
self._start_time = self._current_time
else:
self._restart_time = self._current_time
# 設置按鈕狀態
self.setPushButton(btn1=False, btn2=True, btn3=True)
def pauseTimer(self):
self._pause_flag = True
self._pause_time = self._current_time
# 停止發送信號
self.timer.stop()
self.setPushButton(btn1=True, btn2=False, btn3=True)
def clearTimer(self):
# 還原至初始狀態
self.init_setting()
self.timer.stop()
self.setPushButton()
[Python實戰]你也能寫的計時器程序

樣式設定

成品展示:

[Python實戰]你也能寫的計時器程序

將 label 設定為黑底白字, 字體大小為: 50px,加粗。

self.label.setStyleSheet(
"QLabel{background:rgb(0, 0, 0);}"
"QLabel{color:rgb(250, 250, 250, 250);
font-size:50px; font-weight:bold}")

設定按鈕狀態,pushButton.setEnabled(boolen) 設定按鈕是否可以點擊,默認清零按鈕不可點擊。* 表示僅限關鍵字參數,必須通過關鍵字傳參,不能通過位置參數傳參。

def setPushButton(self, *, btn1=True, btn2=False, btn3=False):
# 設置按鈕狀態
self.pushButton.setEnabled(btn1)
self.pushButton_2.setEnabled(btn2)
self.pushButton_3.setEnabled(btn3)

初始化設置:

def init_setting(self):
# 初始化設置
self._start_time = None
self._pause_flag = False
self._pause_time = 0
self._restart_time = 0
self._pause_total = 0
self.label.setText("00:00:00")

最後,我們可以使用 pyinstaller -w -i timer.ico First_window.py 命令生成 exe 文件。

好了,以上便是這篇文章的全部內容了。如果你喜歡這篇文章,請給我點贊、轉發,分享給你的好友們!

如果你想要本次教程的相關源碼,請關注公眾號:Python高效編程,發送計時器,便會得到相應的下載地址。

往期文章一覽


分享到:


相關文章: