用Python實現(xiàn)一個打字速度測試工具來測試你的手速
一、程序解讀
本次程序中,我們使用的python庫完全是python的內(nèi)置庫,其中界面的制作是利用tkinter進行制作。核心程序可以分為三個部分,分別為:
- 文本顯示
- 文本的輸入檢查
- 結(jié)果計算和顯示
二、文本內(nèi)容的顯示
在程序初始運行階段和點擊“切換文本”按鈕后,都需要在軟件的界面中顯示文本,其程序如下圖所示。

程序中self.Reset函數(shù)的作用是將界面中的內(nèi)容全部重置,設(shè)置為初始值,當(dāng)我們在界面中點擊“重置”按鈕或者是初次運行程序時都會調(diào)用self.Reset函數(shù),其效果如下圖所示。

而對比文本的顯示,則是通過調(diào)用self.getSentence函數(shù)來實現(xiàn),程序讀取本地的sentences.txt文本后,讀取所有的文本內(nèi)容,其中每一行都是一個獨立的句子。
通過random庫中的choice函數(shù)來隨機選擇一個句子,并顯示在界面當(dāng)中,當(dāng)我們點擊“切換文本”按鈕后,就可以實現(xiàn)在界面中更換文本,如下圖所示:

三、文本的輸入檢查
在界面中顯示文本后,接下來就是在下方的輸入框中,抄寫上面的文本內(nèi)容。這里的文本內(nèi)容,我們是通過tkinter庫中的StringVar對象來進行跟蹤,程序如下圖所示:


當(dāng)我們輸入文本時,通過StringVar對象的trace函數(shù)來實時跟蹤文本,并執(zhí)行self.check函數(shù),self.check函數(shù)的作用是當(dāng)開始輸入文本時,設(shè)置self.start_time為文本輸入的時間。
當(dāng)我們輸入文本的長度和展示的文本長度一致時,程序會自動調(diào)用self.result函數(shù),來進行結(jié)果的計算和顯示。其效果如下圖所示。

四、結(jié)果計算和顯示
對于打字速度的計算和顯示,則是通過調(diào)用self.result函數(shù)來實現(xiàn)的,其程序如下圖所示:

程序獲取用戶輸入的文本內(nèi)容,然后通過計算用戶的輸入文本和正確的文本之間的匹配程序來計算打字的準(zhǔn)確率,通過計算用戶打字的計算時間來計算用戶的打字速度,并顯示在界面中,效果如下圖所示:

五、完整代碼
話不多說,最后直接上硬貨——源碼:(注意:需要自己建立一個sentences.txt文件放入到同文件夾下)
import time
from random import choice
from tkinter import Tk, Label, CENTER, LEFT, StringVar, Entry,Button,DISABLED, END,NORMAL
class typeSpeed(object):
def __init__(self):
self.start_time = 0
self.sentence_words_num = 0
self.sentence = ""
self.root = Tk()
self.root.geometry("900x450+300+100")
self.root.title("Python打字測速")
self.root.config(bg="#FFFF00")
Label(self.root, text="打字速度測試器", anchor=CENTER, font=(
"times new roman", 50, "bold"), bg="#00154D", fg="#F2BC90").place(x=200, y=30)
self.sentence_label = Label(self.root, text="歡迎使用打字速度測試器",
wraplength=400, anchor=CENTER, font=("宋體", 15, "bold"), bg="#00154D", fg="#ffffff", width=40, justify=LEFT)
self.sentence_label.place(x=200, y=150)
self.text = StringVar()
self.text.trace("w", lambda name, index, mode, text=self.text: self.check(text))
self.input_entry = Entry(self.root, font=("宋體", 15, "bold"),
width=40, textvariable=self.text)
self.input_entry.place(x=200, y=250)
reset_button = Button(self.root, text="重置", font=(
"宋體", 18, "bold"), width=12, bg="#808080", command=self.Reset)
reset_button.place(x=120, y=320)
changetext_button = Button(self.root, text="切換文本", font=(
"宋體", 18, "bold"), width=12, bg="#808080", command=self.getSentence)
changetext_button.place(x=360, y=320)
result_button = Button(self.root, text="結(jié)果", font=(
"宋體", 18, "bold"), width=12, bg="#808080", command=self.result)
result_button.place(x=600, y=320)
self.speed_label = Label(self.root, text="速度: 00 字每分鐘", font=(
"宋體", 15, "bold"), bg="#f28500", fg="#ffffff")
self.speed_label.place(x=120, y=380)
self.accu_label = Label(self.root, text="準(zhǔn)確率: 00%", font=(
"宋體", 15, "bold"), bg="#f28500", fg="#ffffff")
self.accu_label.place(x=380, y=380)
self.time_label = Label(self.root, text="時間: 0 秒", font=(
"宋體", 15, "bold"), bg="#f28500", fg="#ffffff")
self.time_label.place(x=620, y=380)
self.getSentence()
self.root.mainloop()
def Reset(self):
self.input_entry.config(state=NORMAL)
self.input_entry.delete(0, END)
self.start_time = 0
self.speed_label.config(text="速度: 00字每分鐘")
self.accu_label.config(text="準(zhǔn)確率: 00%")
self.time_label.config(text="時間: 0 秒")
def getSentence(self):
self.Reset()
with open("./sentences.txt", "r", encoding="utf-8") as f:
sentences = f.readlines()
self.sentence = choice(sentences).rstrip()
self.sentence_label.config(text=self.sentence)
self.sentence_words_num = len(self.sentence)
def result(self):
duration = round(time.time() - self.start_time)
input_text = self.text.get()
wpm = round((len(input_text)/duration)*60)
count = 0
for index, char in enumerate(input_text):
if self.sentence[index] == char:
count += 1
accu = round((count/self.sentence_words_num)*100)
self.speed_label.config(text="速度: {} 字每分鐘".format(wpm))
self.accu_label.config(text="準(zhǔn)確率: {}%".format(accu))
self.time_label.config(text="時間: {} 秒".format(duration))
def check(self, text):
if self.start_time == 0 and len(text.get()) == 1:
self.start_time = time.time()
elif len(text.get()) == self.sentence_words_num:
self.input_entry.config(state=DISABLED)
self.result()
if __name__ == '__main__':
到此這篇關(guān)于用Python實現(xiàn)一個打字測試工具來測試你的打字速度的文章就介紹到這了,更多相關(guān)Python打字測試器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python 實現(xiàn)二維字典的鍵值合并等函數(shù)
今天小編就為大家分享一篇python 實現(xiàn)二維字典的鍵值合并等函數(shù),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12
python中websockets與主線程傳遞參數(shù)的實現(xiàn)
本文主要介紹了python中websockets與主線程傳遞參數(shù)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-02-02
使用Python實現(xiàn)ELT統(tǒng)計多個服務(wù)器下所有數(shù)據(jù)表信息
這篇文章主要介紹了使用Python實現(xiàn)ELT統(tǒng)計多個服務(wù)器下所有數(shù)據(jù)表信息,ETL,是英文Extract-Transform-Load的縮寫,用來描述將數(shù)據(jù)從來源端經(jīng)過抽取(extract)、轉(zhuǎn)換(transform)、加載(load)至目的端的過程,需要的朋友可以參考下2023-07-07
Playwright元素截圖并保存至allure的實現(xiàn)示例
在UI自動化測試中,我們經(jīng)常需要獲取屏幕截圖,本文就介紹一下Playwright元素截圖并保存至allure的實現(xiàn)示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12
使用Python代碼實現(xiàn)PDF文檔與SVG文件之間的轉(zhuǎn)換
PDF作為普遍采用的文件格式,確保了文檔的一致性和可靠性,而SVG(可縮放矢量圖形)則因其矢量性質(zhì),在網(wǎng)頁設(shè)計、高分辨率打印及動態(tài)交互內(nèi)容中展現(xiàn)出無與倫比的優(yōu)勢,本文將介紹如何使用Python將PDF文件轉(zhuǎn)換為SVG文件以及將SVG文件轉(zhuǎn)換為PDF文件,需要的朋友可以參考下2024-05-05
Pytorch出現(xiàn)錯誤Attribute?Error:module?‘torch‘?has?no?attrib
這篇文章主要給大家介紹了關(guān)于Pytorch出現(xiàn)錯誤Attribute?Error:module?‘torch‘?has?no?attribute?'_six'解決的相關(guān)資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2023-11-11

