Python学习之旅:用Python制作一个打字训练小工具
一、写在前面
说道程序员,你会想到什么呢?有人认为程序员象征着高薪,有人认为程序员都是死肥宅,还有人想到的则是996和 icu。
别人眼中的程序员:飞快的敲击键盘、酷炫的切换屏幕、各种看不懂的字符代码。
然而现实中的程序员呢?对于很多程序员来说,没有百度和 google 解决不了的问题,也没有 ctrl + c 和 ctrl + v 实现不了的功能。
那么身为一个程序员,要怎么让自己看起来更加“专业”呢?答案就是加快自己的打字速度了,敲的代码可能是错的,但这个13却是必须装的!
然而还是有不少人打字不那么快的,可能就需要训练下了,但是既然身为程序员,为何不自己写一个训练打字的小工具出来呢?
二、基本思路
使用 pyqt5 开发 gui,实现显示句子并让用户输入,然后将输入的内容和给出的句子进行比对,同时记录所用的时间,最后将正确率输出来。为了能够持续打字输入,还需要做一个“下一句”的功能。在实现了这两个基本的功能后,一个简单的打字训练小工具就做出来了。
三、界面设计
1.环境配置
pyqt5 的开发环境配置在上一篇博客中已经说过了,因而这里不再赘述,如果不清楚的可以点这里查看。
2.界面设计
要进行界面设计,得先打开 qtdesigner,然后新建项目,选择 widget:
然后就往里面拖控件就好了,这还是很方便的,主要用的控件包括 label、text edit、push button等,双击控件之后可以在右侧修改控件的各种属性。最终设计出的界面如下:
3.生成 python 代码
在设计完界面之后,将生成的结果保存下来,会得到一个 .ui 为后缀的文件。这个文件我们还是无法直接使用的,需要转变成 python 代码才行。此时就需要使用 pyuic5 命令了,不懂的可以点这里查看我的上篇博客。
四、槽函数
1.槽函数简介
要进行功能设计,就得先知道槽函数。槽是普通的 c++ 成员函数,槽在 qt 开发软件中是一个很重要的概念,在 qt 里与信号连接的就是槽,我们一般称之为槽函数。
在使用信号的时候,有四个参数:
1)sender:发出信号的对象;
2)signal:发送对象发出的信号;
3)receiver:接收信号的对象;
4)slot:接收对象在接收到信号之后所需要调用的函数(槽函数)。
2.使用方法
(1)第一种方法
第一步,在 qtdesigner 中点击 “edit signals/slots”,然后左键点击按钮后将鼠标拖到另一个 label 上:
第二步,在弹出的设置框中选择具体的方法及功能。
这样做很简单,但是也有缺陷,问题在于不能自定义方法,只能使用给定的方法。
(2)第二种方法
在右下角找到 “signal/slot editor” 并点击,然后就可以点击 “+” 创建信号了。
这种方法能够让我们自定义了,但是也不算方便,尤其是当你不知道具体要实现什么方法的时候。
(3)第三种方法
使用 connect() 方法,传入的参数为一个方法名称。例如:
btn.clicked.connect(func)
五、功能实现
1.继承函数
使用 pyuic5 生成 py 文件中定义了一个 ui_form 类,其中包含了对各种控件的定义等,如果我们要增加其他功能,且直接在这个 py 文件中修改的话,那么之后要更新界面之类的就不会不方便了,所以最好的方法是继承 ui_form 类,然后在继承类中添加修改。参考代码如下:
1 import sys 2 from pyqt5 import qtwidgets 3 from typing.ui import ui_form 4 5 6 class myform(ui_form, qtwidgets.qwidget): 7 def __init__(self): 8 super(myform, self).__init__() 9 self.setupui(self) 10 11 12 if __name__ == '__main__': 13 app = qtwidgets.qapplication(sys.argv) 14 my_form = myform() 15 my_form.show() 16 sys.exit(app.exec_())
2.隐藏显示控件
有时候我们可能会需要将某些控件隐藏起来,这里简单介绍几种方法。
1)sethidden(bool) 设置控件是否隐藏;
2)hide() 隐藏控件;
这两种隐藏的方法会完全隐藏控件,即不保留控件所占的位置。但如果要保留位置的话,可以使用下面这种方法:
# 将透明度设置为0,达到隐藏且保留位置的目的
op = qtwidgets.qgraphicsopacityeffect()
op.setopacity(0)
self.lable.setgraphicseffect(op)
3.判断输入内容
这一功能的实现需要在点击“提交”按钮时获取输入框中的内容,再和给出的文本进行对比,最后将结果返回显示出来。
1 def click(self): 2 """ 3 点击按钮时调用 4 :return: 5 """ 6 self.get_time() 7 the_input = self.textedit.toplaintext() 8 # 计算准确率 9 count = 0 10 for i in range(len(the_input)): 11 if the_input[i] == self.text[i]: 12 count += 1 13 accuracy = count / len(self.text) * 100 14 # print(accuracy) 15 self.show_label() 16 # 设置提示信息 17 info = "有点可惜,你的正确率是: %.2f%% " % accuracy if accuracy != 100 else "恭喜你全对了呢!继续加油哦!" 18 self.info_lable.settext(info)
对于我这种懒人来说,点击按钮这种操作都是费力的,所以最好加入一个快捷键,这样就方便多了,可以使用如下方法设置:
# 设置快捷键
self.submit_btn.setshortcut('ctrl+e')
六、运行结果
最终运行结果的截图如下:
提交之后还可以点击下一句继续训练:
完整代码已上传到 github!