基于pyqt5和openpyxl和Pyinstaller的青年大学习检查未学习人数的脚本
前几天接到团支书的一个需求,因为学校给的名单是青年大学习已学习的名单,然而要知道未学习的名单只能从所有团员中再排查一次,过程相当麻烦。团支书跟我抱怨后,刚好我也学过一些操作办公软件的基础、打包python的基础、再加上最近在学pyqt5,所以我决定用python写个自动操作文件的脚本给她用用。
首先,那肯定是用python获取学校发下来的未学习名单,但是我忘记我之前用什么来操作办公软件了(最后项目作出来的时候才想起来是pandas),我就上网搜了一下,试了很多库但是都不支持xlsx文件格式(只支持最老版本的xls),最终openpyxl成功的读取了xlsx文件,于是我就用了openpyxl库来读取文件,下面是python代码
- 1 studyedstudent = []
- 2 wb = load_workbook(xlsx_path)
- 3 sheets = wb.worksheets # 获取当前所有的sheet
- 4 sheet1 = sheets[0]
- 5 for col in sheet1['A']:
- 6 studyedstudent.append(col.value)
这样studyedstudent列表中就是本期已学习的名单了
我又向团支书要了我们班的团员表,同样用该方法读出了我们班的团员,我将他放入一个列表中,当常量来用。
剩下的就是遍历我们班团员,看一下团员是否在已学习的名单中,如果不在,则将该团员放入另一个列表(未学习名单中)
下面是python代码
- wb = load_workbook(xlsx_path)
- sheets = wb.worksheets # 获取当前所有的sheet
- myclassstudent = ['陈荣森', '邓京锐', '邓文凯', '何江伟', '何锦胜', '李春江', '李锦科', '廖金威', '廖钧濠', '林荣添', '刘继洪', '罗炜芊', '麦洋华', '彭浩林', '唐爱萍', '涂骏', '冼东潮', '肖华锋', '谢泽琛', '杨奋发', '张杰森', '郑佳浩', '植美麟', '周天宝']
- # 24团员
- # print(len(myclassstudent))
- # 获取第一张sheet
- sheet1 = sheets[0]
- studyedstudent = []
- for col in sheet1['A']:
- studyedstudent.append(col.value)
- # print(studyedstudent)
- unstudyedstudent = []
- for i in myclassstudent:
- if i not in studyedstudent:
- unstudyedstudent.append(i)
这样一波操作,unstudystudent中就是要给团支书的未学习名单了!
但是鉴于使用者可能没有python环境,所以我决定将unstudystudent写入一个txt文件中,并且将代码打包成exe文件。
下面是代码
- wb = load_workbook(xlsx_path)
- sheets = wb.worksheets # 获取当前所有的sheet
- myclassstudent = ['陈荣森', '邓京锐', '邓文凯', '何江伟', '何锦胜', '李春江', '李锦科', '廖金威', '廖钧濠', '林荣添', '刘继洪', '罗炜芊', '麦洋华', '彭浩林', '唐爱萍', '涂骏', '冼东潮', '肖华锋', '谢泽琛', '杨奋发', '张杰森', '郑佳浩', '植美麟', '周天宝']
- # 24团员
- # print(len(myclassstudent))
- # 获取第一张sheet
- sheet1 = sheets[0]
- studyedstudent = []
- for col in sheet1['A']:
- studyedstudent.append(col.value)
- # print(studyedstudent)
- unstudyedstudent = []
- for i in myclassstudent:
- if i not in studyedstudent:
- unstudyedstudent.append(i)
- file = open('大学习未完成名单.txt', 'w')
- for i in unstudyedstudent:
- file.write(i)
- file.write('\n')
- file.close()
打包需要先下载一个打包的库打开cmd 输入“pip install Pyinstaller”即可,然后再cmd中进入要打包的文件夹,输入“Pyinstaller -F main.py”等待打包即可,main.py是我要打包的文件名字。
但是这是个小黑板使用起来不太方便,我决定做一个GUI,我就用了我最近在学的pyqt5。
首先把main文件封装成函数,下面是main.py的代码
- from openpyxl import load_workbook
- def getnostudytxt(xlsx_path):
- wb = load_workbook(xlsx_path)
- sheets = wb.worksheets # 获取当前所有的sheet
- myclassstudent = ['陈荣森', '邓京锐', '邓文凯', '何江伟', '何锦胜', '李春江', '李锦科', '廖金威', '廖钧濠', '林荣添', '刘继洪', '罗炜芊', '麦洋华', '彭浩林', '唐爱萍', '涂骏', '冼东潮', '肖华锋', '谢泽琛', '杨奋发', '张杰森', '郑佳浩', '植美麟', '周天宝']
- # 24团员
- # print(len(myclassstudent))
- # 获取第一张sheet
- sheet1 = sheets[0]
- studyedstudent = []
- for col in sheet1['A']:
- studyedstudent.append(col.value)
- # print(studyedstudent)
- unstudyedstudent = []
- for i in myclassstudent:
- if i not in studyedstudent:
- unstudyedstudent.append(i)
- file = open('大学习未完成名单.txt', 'w')
- for i in unstudyedstudent:
- file.write(i)
- file.write('\n')
- file.close()
- return unstudyedstudent
接下来是写界面,不妨命名为ui.py,下面是代码。
- import sys
- from PyQt5.QtWidgets import (QWidget, QTextEdit, QFileDialog, QApplication, QHBoxLayout, QVBoxLayout, QPushButton)
- from PyQt5.QtGui import QIcon
- import main
- class Example(QWidget):
- def __init__(self):
- super().__init__()
- self.initUI()
- def initUI(self):
- okButton = QPushButton("选择文件")
- self.textEdit = QTextEdit()
- okButton.clicked.connect(self.showDialog)
- vvbox = QVBoxLayout()
- vvbox.addWidget(okButton)
- vvbox.addStretch(1)
- hbox = QHBoxLayout()
- hbox.addLayout(vvbox)
- hbox.addWidget(self.textEdit)
- vbox = QVBoxLayout()
- vbox.addLayout(hbox)
- self.setLayout(vbox)
- self.setGeometry(300, 300, 350, 300)
- self.setWindowTitle("青年大学习获取未学习名单")
- self.setWindowIcon(QIcon("head.ico"))
- self.show()
- def showDialog(self):
- # 弹出文件选择器
- fname = QFileDialog.getOpenFileName(self, "Open file")
- # 如果选择了文件
- if fname[0]:
- # 打开第一个文件
- f = open(fname[0], "r")
- print(f.name)
- mylist = main.getnostudytxt(f.name)
- print(mylist)
- for i in mylist:
- self.textEdit.append(i)
- if __name__ == "__main__":
- app = QApplication(sys.argv)
- ex = Example()
- sys.exit(app.exec_())
最后就是打包了,这次要打包的是窗口文件,所以打包的指令中要多加一个-w,而且我给打包后的文件添加了一个图标(head.ico),所以输入“Pyinstaller -F -w -i head.ico ui.py”。
最终项目就做完了!
代码我已经提交到github上,如果想瞅瞅源码可以上我的github上看看:xddno1/python_student_big_study: 青年大学习检查未学习名单的python脚本 (github.com)
最后还有一个小bug,那就是pyqt5窗口的图标不展示的问题,这个有知道的大佬还请指出解决办法!
基于pyqt5和openpyxl和Pyinstaller的青年大学习检查未学习人数的脚本的更多相关文章
- 制作属于自己的翻译软件(基于PyQt5+Python+实时翻译)
目录 制作属于自己的翻译软件(基于PyQt5+Python+实时翻译) 翻译软件上传到github上. 软件截图 主要的思想 界面方面 程序方面 制作属于自己的翻译软件(基于PyQt5+Python+ ...
- 基于PYQT5的截图翻译工具
基于PYQT5的截图翻译工具 功能介绍 翻译功能 截图功能(快捷键 + 截图存储到剪切板中) 文字识别OCR(基于百度API的文字识别) UI 界面 截图 截图可以使用第三方截图 或 使用PyQt5截 ...
- 02基于python玩转人工智能最火框架之TensorFlow人工智能&深度学习介绍
人工智能之父麦卡锡给出的定义 构建智能机器,特别是智能计算机程序的科学和工程. 人工智能是一种让计算机程序能够"智能地"思考的方式 思考的模式类似于人类. 什么是智能? 智能的英语 ...
- 基于深度学习和迁移学习的识花实践——利用 VGG16 的深度网络结构中的五轮卷积网络层和池化层,对每张图片得到一个 4096 维的特征向量,然后我们直接用这个特征向量替代原来的图片,再加若干层全连接的神经网络,对花朵数据集进行训练(属于模型迁移)
基于深度学习和迁移学习的识花实践(转) 深度学习是人工智能领域近年来最火热的话题之一,但是对于个人来说,以往想要玩转深度学习除了要具备高超的编程技巧,还需要有海量的数据和强劲的硬件.不过 Tens ...
- 学习《深度学习入门:基于Python的理论与实现》高清中文版PDF+源代码
入门神经网络深度学习,推荐学习<深度学习入门:基于Python的理论与实现>,这本书不来虚的,一上来就是手把手教你一步步搭建出一个神经网络,还能把每一步的出处讲明白.理解神经网络,很容易就 ...
- 微信小程序--基于ColorUI构建皮皮虾短视频去水印组件(仅供学习使用)
微信小程序--基于ColorUI构建皮皮虾短视频去水印组件(仅供学习使用) 没错,我是皮友,我想学习舞蹈(/doge)和瑜伽 ,要无水印的那种有助于我加深学习. 1.组件效果展示 2.组件引入准备 h ...
- 基于pyQt5开发的股价显示器(原创)
#/usr/bin/env python # -*- coding: utf-8 -*- ''' @author="livermorium116" 为了绕开公司内网而开发的 股票实 ...
- 基于PyQt5的Python-Gui开发
环境搭建 电脑环境 win10 64位系统 Python3.5安装 从Python官网下载python3.5安装文件,选择windows 64位版本python-3.6.5-amd64.exe.双击安 ...
- 基于pyqt5的图片素材批量处理工具
功能 分辨率的批量转换,文件夹递归查找 像素偏移量批量调整,文件夹单层查找 画布的大小的批量进行调整,不进行缩放,文件夹单层查找 界面 通过PyUIC生成的代码 # -*- coding: utf-8 ...
随机推荐
- vue-i18n 国际化语言切换
vue-i18n 用于前端vue项目中,需要多语言切换的场景 安装方法(npm) npm install vue-i18n 简单使用 1.在vue项目的main.ts文件中实例化 i18n imp ...
- 面试高频题:说一说对Spring和SpringMvc父子容器的理解?
引言 以前写了几篇关于SpringBoot的文章<面试高频题:springBoot自动装配的原理你能说出来吗>.<保姆级教程,手把手教你实现一个SpringBoot的starter& ...
- C# .NET Socket 简单实用框架,socket组件封装
参考资料 https://www.cnblogs.com/coldairarrow/p/7501645.html 根据.NET Socket 简单实用框架进行了改造,这个代码对socket通信封装还是 ...
- kubernetes dashboard 2.0 部署
dashboard 可以从微软中国提供的 gcr.io :http://mirror.azure.cn/help/gcr-proxy-cache.html免费代理下载被墙的镜像 docker pull ...
- 从 lite-apiserver 看 SuperEdge 边缘节点自治
引言 在 SuperEdge 0.2.0版本中,lite-apiserver 进行了重大的架构升级和功能增强.本文将从 lite-apiserver 实现及其与其它 SuperEdge 组件协同的角度 ...
- Dynamics Crm Plugin插件注册的问题及解决方案(持续更新。。。。。。)
1.注册插件的时候回遇到如下提示 Plug-in assembly does not contain the required types or assembly content cannot be ...
- 通过Dapr实现一个简单的基于.net的微服务电商系统(三)——一步一步教你如何撸Dapr
目录:一.通过Dapr实现一个简单的基于.net的微服务电商系统 二.通过Dapr实现一个简单的基于.net的微服务电商系统(二)--通讯框架讲解 三.通过Dapr实现一个简单的基于.net的微服务电 ...
- java面试一日一题:请讲下对mysql的理解
问题:请讲下对mysql的理解 分析:该问题主要考察对mysql的理解,基本概念及sql的执行流程 回答要点: 主要从以下几点去考虑, 1.mysql的整体架构? 2.mysql中每一个组件的作用? ...
- Nginx的进程管理与重载原理
目录 进程结构图 信号量管理 Linux的信号量管理机制 利用信号量管理Nginx进程 配置文件重载原理 进程结构图 Nginx是多进程结构,多进程结构设计是为了保证Nginx的高可用高可靠,包含: ...
- java多种文件复制方式以及效率比较
1.背景 java复制文件的方式其实有很多种,可以分为 传统的字节流读写复制FileInputStream,FileOutputStream,BufferedInputStream,BufferedO ...