侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

PyQt5实现简易电子词典

Python  /  管理员 发布于 5年前   286

PyQt5是python中一个非常实用的GUI编程模块,功能十分强大。刚刚学完了Pyqt的编程,就迫不及待的写出了一个电子词典GUI程序。整个程序使用qt Desiner把整个gui界面做好,槽函数则自己写好的。电子词典实现了查询单词,查询历史记录,收藏和查看单词本的功能,另外为了是程序更加炫酷,还添加了一个启动界面。具体代码如下:

第一个为主程序代码,主要实现槽函数功能。

from PyQt5.QtCore import pyqtSlotfrom PyQt5.QtWidgets import QMainWindowfrom PyQt5 import QtWidgetsfrom Ui_E_Dict_Main import Ui_E_Dictoryfrom PyQt5.QtWidgets import *from PyQt5.QtGui import *from PyQt5.QtCore import *import time, re # 槽函数代码,运行程序需要运行本文件class MainWindow(QMainWindow, Ui_E_Dictory): """ Class documentation goes here. """ def __init__(self, parent=None):  """  Constructor    @param parent reference to the parent widget  @type QWidget  """  super(MainWindow, self).__init__(parent)  self.setupUi(self)  # 启动时休眠1秒  time.sleep(1)  # 按钮1 查找单词,把单词显示在textBrowser的同时,插入历史记录 @pyqtSlot() def on_pushButton_clicked(self):  """  Slot documentation goes here.  """  # 单词查询,需要先有一个'dict.txt'文件,其中有大量的英文单词和注释  # 此处也可以先把'dict.txt'插入数据库,历史记录和单词本的插入和查询都可以直接操作数据库  # 不过数据库需要事先安装数据库,并建立相应的表,不好打包,不太方便  word=self.lineEdit.text()  f=open('dict.txt', 'r')  for line in f:   # 对字典文件的数据进行分析,拆解为适合显示的格式   l = re.split('[ ]+',line)   if l[0]==word:    interpret=' '.join(l[1:])    data='%s\n %s'%(l[0], interpret)    # interpret='%s: %s'%(l[0],' '.join(l[1:]))    self.textBrowser.setText(data)    # 当地时间    t1=time.localtime()    t2=time.asctime(t1)    #self.lineEdit.setText("")#lineEdit输入后清零,可要可不要    try:     # 把所查询单词插入历史记录中,     #'a'以只写文件打开一个文件,如果有原文件则追加到文件末尾     file=open('history.txt', 'at')     msg='%s %s'%(word, t2)     file.write(msg)     file.write('\n')     file.close()    except Exception as e:     print(e)  f.close()        @pyqtSlot() def on_pushButton_2_clicked(self):  """  Slot documentation goes here.  """  try:   # 查询历史记录,把历史记录显示在textBrowser中   file=open('history.txt', 'rt')      list=file.readlines()   msg=''.join(list)   self.textBrowser.setText(msg)   file.close()  except Exception as e:     print(e)        @pyqtSlot() def on_pushButton_3_clicked(self):  """  Slot documentation goes here.  """  try:   # 查询单词本,把单词本显示在textBrowser中   file=open('words.txt', 'rt')      list=file.readlines()   msg=''.join(list)   self.textBrowser.setText(msg)   file.close()  except Exception as e:     print(e)     @pyqtSlot() def on_pushButton_4_clicked(self):  """  Slot documentation goes here.  """  word=self.lineEdit.text()  try:   # 把所查询单词插入单词本中   file=open('words.txt', 'at')   file.write(word)   file.write('\n')   file.close()  except Exception as e:   print(e)       if __name__ == "__main__": import sys app = QtWidgets.QApplication(sys.argv) # 启动界面的实现,可以使程序更加炫酷 splash=QtWidgets.QSplashScreen(QPixmap("Saved Pictures/5b517f520feaa.jpg")) # 启动界面显示 splash.show() # 在启动界面中显示程序加载进度,参数意思分别为居中显示,蓝色字体 splash.showMessage('正在加载图片资源', Qt.AlignCenter, Qt.blue) time.sleep(1) # 为了不与主程序干扰 app.processEvents() ui = MainWindow() ui.show() # 启动界面完成 splash.finish(ui) sys.exit(app.exec_())

第二个程序代码,主要实现整体的GUI界面的构建(使用Qtdesiner可以极大的简化工作量,强烈推荐)

from PyQt5 import QtCore, QtGui, QtWidgets class Ui_E_Dictory(object): def setupUi(self, E_Dictory):  E_Dictory.setObjectName("E_Dictory")  E_Dictory.resize(658, 474)  icon = QtGui.QIcon()  icon.addPixmap(QtGui.QPixmap("icon/24-monitor.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)  E_Dictory.setWindowIcon(icon)  self.centralWidget = QtWidgets.QWidget(E_Dictory)  self.centralWidget.setObjectName("centralWidget")  self.pushButton = QtWidgets.QPushButton(self.centralWidget)  self.pushButton.setGeometry(QtCore.QRect(390, 400, 91, 31))  font = QtGui.QFont()  font.setFamily("黑体")  font.setPointSize(14)  self.pushButton.setFont(font)  self.pushButton.setObjectName("pushButton")  self.label_2 = QtWidgets.QLabel(self.centralWidget)  self.label_2.setGeometry(QtCore.QRect(100, 400, 51, 31))  font = QtGui.QFont()  font.setFamily("黑体")  font.setPointSize(14)  self.label_2.setFont(font)  self.label_2.setObjectName("label_2")  self.textBrowser = QtWidgets.QTextBrowser(self.centralWidget)  self.textBrowser.setGeometry(QtCore.QRect(100, 110, 381, 271))  self.textBrowser.setStyleSheet("background-color: rgb(242, 255, 233);")  self.textBrowser.setObjectName("textBrowser")  self.lineEdit = QtWidgets.QLineEdit(self.centralWidget)  self.lineEdit.setGeometry(QtCore.QRect(160, 400, 211, 31))  font = QtGui.QFont()  font.setFamily("楷体")  font.setPointSize(10)  self.lineEdit.setFont(font)  self.lineEdit.setText("")  self.lineEdit.setObjectName("lineEdit")  self.label = QtWidgets.QLabel(self.centralWidget)  self.label.setGeometry(QtCore.QRect(240, 60, 151, 31))  font = QtGui.QFont()  font.setFamily("楷体")  font.setPointSize(14)  font.setBold(False)  font.setWeight(50)  self.label.setFont(font)  self.label.setObjectName("label")  self.pushButton_2 = QtWidgets.QPushButton(self.centralWidget)  self.pushButton_2.setGeometry(QtCore.QRect(510, 140, 75, 23))  self.pushButton_2.setObjectName("pushButton_2")  self.pushButton_3 = QtWidgets.QPushButton(self.centralWidget)  self.pushButton_3.setGeometry(QtCore.QRect(510, 220, 75, 23))  self.pushButton_3.setObjectName("pushButton_3")  self.pushButton_4 = QtWidgets.QPushButton(self.centralWidget)  self.pushButton_4.setGeometry(QtCore.QRect(510, 310, 75, 23))  self.pushButton_4.setObjectName("pushButton_4")  self.graphicsView = QtWidgets.QGraphicsView(self.centralWidget)  self.graphicsView.setGeometry(QtCore.QRect(0, 0, 661, 471))  self.graphicsView.setStyleSheet("border-image: url(:/pic/Saved Pictures/f3cb924702022fc35eb6f865d67e23a6.jpg);")  self.graphicsView.setObjectName("graphicsView")  self.graphicsView.raise_()  self.pushButton.raise_()  self.label_2.raise_()  self.textBrowser.raise_()  self.lineEdit.raise_()  self.label.raise_()  self.pushButton_2.raise_()  self.pushButton_3.raise_()  self.pushButton_4.raise_()  E_Dictory.setCentralWidget(self.centralWidget)   self.retranslateUi(E_Dictory)  QtCore.QMetaObject.connectSlotsByName(E_Dictory)  def retranslateUi(self, E_Dictory):  _translate = QtCore.QCoreApplication.translate  E_Dictory.setWindowTitle(_translate("E_Dictory", "无道词典"))  self.pushButton.setText(_translate("E_Dictory", "查找"))  # 快捷键回车,可以使查找按钮发生效果  self.pushButton.setShortcut(_translate("E_Dictory", "Return"))  self.label_2.setText(_translate("E_Dictory", "单词:"))  # setHtml样式表可以按照自己喜好修改  self.textBrowser.setHtml(_translate("E_Dictory", "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.0//EN\" \"http://www.w3.org/TR/REC-html40/strict.dtd\">\n""<html><head><meta name=\"qrichtext\" content=\"1\" /><style type=\"text/css\">\n""p, li { white-space: pre-wrap; }\n""</style></head><body style=\" font-family:\'SimSun\'; font-size:9pt; font-weight:400; font-style:normal;\">\n""<p style=\" margin-top:12px; margin-bottom:12px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;\"><br /></p></body></html>"))  self.label.setText(_translate("E_Dictory", "查询单词"))  self.pushButton_2.setText(_translate("E_Dictory", "历史记录"))  self.pushButton_3.setText(_translate("E_Dictory", "单词本"))  self.pushButton_4.setText(_translate("E_Dictory", "添加单词")) import dict_rc if __name__ == "__main__": import sys app = QtWidgets.QApplication(sys.argv) E_Dictory = QtWidgets.QMainWindow() ui = Ui_E_Dictory() ui.setupUi(E_Dictory) E_Dictory.show() sys.exit(app.exec_())

textBrowser中的内容可以以html的格式显示出来,所有其中的文件的显示可以按照自己的喜好来设计。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    使用pyinstaller打包PyQt4程序遇到的问题及解决方法
    下一条:
    PYQT5实现控制台显示功能的方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客