【脚本项目源码】Python实现鲁迅名言查询系统

前言

本文给大家分享的是如何通过利用Python实现鲁迅名言查询系统,废话不多直接开整~

开发工具

Python版本: 3.6

相关模块:

PyQt5模块

fuzzywuzzy模块

环境搭建

安装Python并添加到环境变量,pip安装需要的相关模块即可。

文中实战教程,评论留言获取。

代码实现

简单的GUI

class GUI(QWidget):
	def __init__(self, parent=None):
		super().__init__()
		self.setWindowTitle('鲁迅名言查询-公众号:Python工程狮')
		self.setWindowIcon(QIcon('data/icon.png'))
		self.label1 = QLabel('句子:')
		self.line_edit = QLineEdit()
		self.label2 = QLabel('查询结果:')
		self.text = QTextEdit()
		self.button = QPushButton()
		self.button.setText('查询')
		self.cmb = QComboBox()
		self.cmb.setStyle(QStyleFactory.create('Fusion'))
		self.cmb.addItem('匹配度: 100%')
		self.cmb.addItem('匹配度: 90%')
		self.cmb.addItem('匹配度: 80%')
		self.cmb.addItem('匹配度: 70%')
		self.grid = QGridLayout()
		self.grid.setSpacing(12)
		self.grid.addWidget(self.label1, 1, 0)
		self.grid.addWidget(self.line_edit, 1, 1, 1, 38)
		self.grid.addWidget(self.button, 1, 39)
		self.grid.addWidget(self.label2, 2, 0)
		self.grid.addWidget(self.text, 2, 1, 1, 40)
		self.grid.addWidget(self.cmb, 1, 40)
		self.setLayout(self.grid)
		self.resize(600, 400)
		self.button.clicked.connect(self.inquiry)
		self.paragraphs = self.loadData('data/book.txt')

查询

def inquiry(self):
		sentence = self.line_edit.text()
		matched = []
		score_thresh = self.getScoreThresh()
		if not sentence:
			QMessageBox.warning(self, "Warning", '请先输入需要查询的鲁迅名言')
		else:
			for p in self.paragraphs:
				score = fuzz.partial_ratio(p, sentence)
				if score >= score_thresh and len(sentence) <= len(p):
					matched.append([score, p])
			infos = []
			for match in matched:
				infos.append('[匹配度]: %d\n[内容]: %s\n' % (match[0], match[1]))
			if not infos:
				infos.append('未匹配到任何相似度大于%d的句子.\n' % score_thresh)
			self.text.setText('\n\n\n'.join(infos)[:-1])

根据下拉框选项获取匹配度

def getScoreThresh(self):
		if self.cmb.currentIndex() == 0:
			return 100
		elif self.cmb.currentIndex() == 1:
			return 90
		elif self.cmb.currentIndex() == 2:
			return 80
		elif self.cmb.currentIndex() == 3:
			return 70

数据导入

def loadData(self, data_path):
		paragraphs = []
		with open(data_path, 'r', encoding='utf-8') as f:
			for line in f.readlines():
				if line.strip():
					paragraphs.append(line.strip('\n'))
		return paragraphs

运行

if __name__ == '__main__':
	app = QApplication(sys.argv)
	gui = GUI()
	gui.show()
	sys.exit(app.exec_())

结果展示

鲁迅名言查询系统

最后

今天的分享到这里就结束了 ,感兴趣的朋友也可以去试试哈

对文章有问题的,或者有其他关于python的问题,可以在评论区留言或者私信我哦

觉得我分享的文章不错的话,可以关注一下我,或者给文章点赞(/≧▽≦)/

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:【脚本项目源码】Python实现鲁迅名言查询系统 - Python技术站

(0)
上一篇 2023年4月2日 下午4:16
下一篇 2023年4月2日 下午4:16

相关文章

  • 【脚本项目源码】Python制作艺术签名生成器,打造专属你的个人艺术签名

    前言 本文给大家分享的是如何通过利用Python制作艺术签名生成器,废话不多直接开整~ 开发工具 Python版本: 3.6 相关模块: requests模块 PIL模块 PyQt5模块 环境搭建 安装Python并添加到环境变量,pip安装需要的相关模块即可。 文中实战教程,评论留言获取。 思路分析 浏览器中打开我们要爬取的页面按F12进入开发者工具,查看…

    Python开发 2023年4月2日
    00
  • 【爬虫实战项目】Python爬虫批量下载网易云音乐飙升榜并保存本地(附源码)

    前言 今天给大家介绍的是Python爬虫批量下载音乐飙升榜并保存本地,在这里给需要的小伙伴们代码,并且给出一点小心得。 首先是爬取之前应该尽可能伪装成浏览器而不被识别出来是爬虫,基本的是加请求头,但是这样的纯文本数据爬取的人会很多,所以我们需要考虑更换代理IP和随机更换请求头的方式来对音乐飙升榜进行爬取。 在每次进行爬虫代码的编写之前,我们的第一步也是最重要…

    Python开发 2023年4月2日
    00
  • 【脚本项目源码】Python制作多功能音乐播放器,打造专属你的音乐播放器

    前言 本文给大家分享的是如何通过利用Python实现多功能音乐播放器,废话不多直接开整~ 开发工具 Python版本: 3.6 相关模块: os模块 sys模块 time模块 random模块 PyQt5模块 环境搭建 安装Python并添加到环境变量,pip安装需要的相关模块即可。 文中完整源码,评论留言获取。 代码实现 初始化 def __initial…

    Python开发 2023年4月2日
    00
  • Python爬虫实战,requests+openpyxl模块,爬取手机商品信息数据(附源码)

    前言 今天给大家介绍的是Python爬取手机商品信息数据,在这里给需要的小伙伴们代码,并且给出一点小心得。 首先是爬取之前应该尽可能伪装成浏览器而不被识别出来是爬虫,基本的是加请求头,但是这样的纯文本数据爬取的人会很多,所以我们需要考虑更换代理IP和随机更换请求头的方式来对手机信息数据进行爬取。 在每次进行爬虫代码的编写之前,我们的第一步也是最重要的一步就是…

    Python开发 2023年4月2日
    00
  • Python爬虫实战,requests+xlwt模块,爬取螺蛳粉商品数据(附源码)

    前言 今天给大家介绍的是Python爬取螺蛳粉商品数据,在这里给需要的小伙伴们代码,并且给出一点小心得。 首先是爬取之前应该尽可能伪装成浏览器而不被识别出来是爬虫,基本的是加请求头,但是这样的纯文本数据爬取的人会很多,所以我们需要考虑更换代理IP和随机更换请求头的方式来对螺蛳粉数据进行爬取。 在每次进行爬虫代码的编写之前,我们的第一步也是最重要的一步就是分析…

    Python开发 2023年4月2日
    00
  • 【Python爬虫实战项目】Python爬虫批量下载喜马拉雅评书音频并保存本地(附源码)

    前言 今天给大家介绍的是Python爬虫批量下载评书音频并保存本地,在这里给需要的小伙伴们代码,并且给出一点小心得。 首先是爬取之前应该尽可能伪装成浏览器而不被识别出来是爬虫,基本的是加请求头,但是这样的纯文本数据爬取的人会很多,所以我们需要考虑更换代理IP和随机更换请求头的方式来对评书精选音频进行爬取。 在每次进行爬虫代码的编写之前,我们的第一步也是最重要…

    Python开发 2023年3月31日
    00
  • 【爬虫实战项目】Python爬取Top100电影榜单数据保存本地(附源码)

    前言 今天给大家介绍的是Python爬取Top100电影榜单数据保存csv文件,在这里给需要的小伙伴们代码,并且给出一点小心得。 首先是爬取之前应该尽可能伪装成浏览器而不被识别出来是爬虫,基本的是加请求头,但是这样的纯文本数据爬取的人会很多,所以我们需要考虑更换代理IP和随机更换请求头的方式来对Top100电影榜单数据进行爬取。 在每次进行爬虫代码的编写之前…

    2023年4月2日
    00
  • 【Python爬虫项目实战】Python爬虫豆瓣Top250电影短评数据保存本地

    前言 今天给大家介绍的是Python爬虫豆瓣Top250电影短评数据保存本地,在这里给需要的小伙伴们帮助,并且给出一点小心得。 开发工具 Python版本:3.6 相关模块: requests模块 parsel模块 time模块 环境搭建 安装Python并添加到环境变量,pip安装需要的相关模块即可。 文中完整代码及文件,评论留言获取 数据来源查询分析 浏…

    2023年3月31日
    00
合作推广
合作推广
分享本页
返回顶部