前几天接到团支书的一个需求,因为学校给的名单是青年大学习已学习的名单,然而要知道未学习的名单只能从所有团员中再排查一次,过程相当麻烦。团支书跟我抱怨后,刚好我也学过一些操作办公软件的基础、打包python的基础、再加上最近在学pyqt5,所以我决定用python写个自动操作文件的脚本给她用用。

首先,那肯定是用python获取学校发下来的未学习名单,但是我忘记我之前用什么来操作办公软件了(最后项目作出来的时候才想起来是pandas),我就上网搜了一下,试了很多库但是都不支持xlsx文件格式(只支持最老版本的xls),最终openpyxl成功的读取了xlsx文件,于是我就用了openpyxl库来读取文件,下面是python代码

  1. 1 studyedstudent = []
  2. 2 wb = load_workbook(xlsx_path)
  3. 3 sheets = wb.worksheets # 获取当前所有的sheet
  4. 4 sheet1 = sheets[0]
  5. 5 for col in sheet1['A']:
  6. 6 studyedstudent.append(col.value)

这样studyedstudent列表中就是本期已学习的名单了

我又向团支书要了我们班的团员表,同样用该方法读出了我们班的团员,我将他放入一个列表中,当常量来用。

剩下的就是遍历我们班团员,看一下团员是否在已学习的名单中,如果不在,则将该团员放入另一个列表(未学习名单中)

下面是python代码

  1. wb = load_workbook(xlsx_path)
  2. sheets = wb.worksheets # 获取当前所有的sheet
  3. myclassstudent = ['陈荣森', '邓京锐', '邓文凯', '何江伟', '何锦胜', '李春江', '李锦科', '廖金威', '廖钧濠', '林荣添', '刘继洪', '罗炜芊', '麦洋华', '彭浩林', '唐爱萍', '涂骏', '冼东潮', '肖华锋', '谢泽琛', '杨奋发', '张杰森', '郑佳浩', '植美麟', '周天宝']
  4. # 24团员
  5. # print(len(myclassstudent))
  6. # 获取第一张sheet
  7. sheet1 = sheets[0]
  8. studyedstudent = []
  9. for col in sheet1['A']:
  10. studyedstudent.append(col.value)
  11. # print(studyedstudent)
  12. unstudyedstudent = []
  13. for i in myclassstudent:
  14. if i not in studyedstudent:
  15. unstudyedstudent.append(i)

这样一波操作,unstudystudent中就是要给团支书的未学习名单了!

但是鉴于使用者可能没有python环境,所以我决定将unstudystudent写入一个txt文件中,并且将代码打包成exe文件。

下面是代码

  1. wb = load_workbook(xlsx_path)
  2. sheets = wb.worksheets # 获取当前所有的sheet
  3. myclassstudent = ['陈荣森', '邓京锐', '邓文凯', '何江伟', '何锦胜', '李春江', '李锦科', '廖金威', '廖钧濠', '林荣添', '刘继洪', '罗炜芊', '麦洋华', '彭浩林', '唐爱萍', '涂骏', '冼东潮', '肖华锋', '谢泽琛', '杨奋发', '张杰森', '郑佳浩', '植美麟', '周天宝']
  4. # 24团员
  5. # print(len(myclassstudent))
  6. # 获取第一张sheet
  7. sheet1 = sheets[0]
  8. studyedstudent = []
  9. for col in sheet1['A']:
  10. studyedstudent.append(col.value)
  11. # print(studyedstudent)
  12. unstudyedstudent = []
  13. for i in myclassstudent:
  14. if i not in studyedstudent:
  15. unstudyedstudent.append(i)
  16. file = open('大学习未完成名单.txt', 'w')
  17. for i in unstudyedstudent:
  18. file.write(i)
  19. file.write('\n')
  20. file.close()

打包需要先下载一个打包的库打开cmd 输入“pip install Pyinstaller”即可,然后再cmd中进入要打包的文件夹,输入“Pyinstaller -F main.py”等待打包即可,main.py是我要打包的文件名字。

但是这是个小黑板使用起来不太方便,我决定做一个GUI,我就用了我最近在学的pyqt5。

首先把main文件封装成函数,下面是main.py的代码

  1. from openpyxl import load_workbook
  2.  
  3. def getnostudytxt(xlsx_path):
  4. wb = load_workbook(xlsx_path)
  5. sheets = wb.worksheets # 获取当前所有的sheet
  6. myclassstudent = ['陈荣森', '邓京锐', '邓文凯', '何江伟', '何锦胜', '李春江', '李锦科', '廖金威', '廖钧濠', '林荣添', '刘继洪', '罗炜芊', '麦洋华', '彭浩林', '唐爱萍', '涂骏', '冼东潮', '肖华锋', '谢泽琛', '杨奋发', '张杰森', '郑佳浩', '植美麟', '周天宝']
  7. # 24团员
  8. # print(len(myclassstudent))
  9. # 获取第一张sheet
  10. sheet1 = sheets[0]
  11. studyedstudent = []
  12. for col in sheet1['A']:
  13. studyedstudent.append(col.value)
  14. # print(studyedstudent)
  15.  
  16. unstudyedstudent = []
  17. for i in myclassstudent:
  18. if i not in studyedstudent:
  19. unstudyedstudent.append(i)
  20. file = open('大学习未完成名单.txt', 'w')
  21.  
  22. for i in unstudyedstudent:
  23. file.write(i)
  24. file.write('\n')
  25. file.close()
  26. return unstudyedstudent

接下来是写界面,不妨命名为ui.py,下面是代码。

  1. import sys
  2. from PyQt5.QtWidgets import (QWidget, QTextEdit, QFileDialog, QApplication, QHBoxLayout, QVBoxLayout, QPushButton)
  3. from PyQt5.QtGui import QIcon
  4. import main
  5.  
  6. class Example(QWidget):
  7. def __init__(self):
  8. super().__init__()
  9. self.initUI()
  10.  
  11. def initUI(self):
  12. okButton = QPushButton("选择文件")
  13. self.textEdit = QTextEdit()
  14. okButton.clicked.connect(self.showDialog)
  15. vvbox = QVBoxLayout()
  16. vvbox.addWidget(okButton)
  17. vvbox.addStretch(1)
  18. hbox = QHBoxLayout()
  19. hbox.addLayout(vvbox)
  20. hbox.addWidget(self.textEdit)
  21. vbox = QVBoxLayout()
  22. vbox.addLayout(hbox)
  23. self.setLayout(vbox)
  24. self.setGeometry(300, 300, 350, 300)
  25. self.setWindowTitle("青年大学习获取未学习名单")
  26. self.setWindowIcon(QIcon("head.ico"))
  27. self.show()
  28.  
  29. def showDialog(self):
  30. # 弹出文件选择器
  31. fname = QFileDialog.getOpenFileName(self, "Open file")
  32. # 如果选择了文件
  33. if fname[0]:
  34. # 打开第一个文件
  35. f = open(fname[0], "r")
  36. print(f.name)
  37. mylist = main.getnostudytxt(f.name)
  38. print(mylist)
  39. for i in mylist:
  40. self.textEdit.append(i)
  41.  
  42. if __name__ == "__main__":
  43. app = QApplication(sys.argv)
  44. ex = Example()
  45. 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的青年大学习检查未学习人数的脚本的更多相关文章

  1. 制作属于自己的翻译软件(基于PyQt5+Python+实时翻译)

    目录 制作属于自己的翻译软件(基于PyQt5+Python+实时翻译) 翻译软件上传到github上. 软件截图 主要的思想 界面方面 程序方面 制作属于自己的翻译软件(基于PyQt5+Python+ ...

  2. 基于PYQT5的截图翻译工具

    基于PYQT5的截图翻译工具 功能介绍 翻译功能 截图功能(快捷键 + 截图存储到剪切板中) 文字识别OCR(基于百度API的文字识别) UI 界面 截图 截图可以使用第三方截图 或 使用PyQt5截 ...

  3. 02基于python玩转人工智能最火框架之TensorFlow人工智能&深度学习介绍

    人工智能之父麦卡锡给出的定义 构建智能机器,特别是智能计算机程序的科学和工程. 人工智能是一种让计算机程序能够"智能地"思考的方式 思考的模式类似于人类. 什么是智能? 智能的英语 ...

  4. 基于深度学习和迁移学习的识花实践——利用 VGG16 的深度网络结构中的五轮卷积网络层和池化层,对每张图片得到一个 4096 维的特征向量,然后我们直接用这个特征向量替代原来的图片,再加若干层全连接的神经网络,对花朵数据集进行训练(属于模型迁移)

    基于深度学习和迁移学习的识花实践(转)   深度学习是人工智能领域近年来最火热的话题之一,但是对于个人来说,以往想要玩转深度学习除了要具备高超的编程技巧,还需要有海量的数据和强劲的硬件.不过 Tens ...

  5. 学习《深度学习入门:基于Python的理论与实现》高清中文版PDF+源代码

    入门神经网络深度学习,推荐学习<深度学习入门:基于Python的理论与实现>,这本书不来虚的,一上来就是手把手教你一步步搭建出一个神经网络,还能把每一步的出处讲明白.理解神经网络,很容易就 ...

  6. 微信小程序--基于ColorUI构建皮皮虾短视频去水印组件(仅供学习使用)

    微信小程序--基于ColorUI构建皮皮虾短视频去水印组件(仅供学习使用) 没错,我是皮友,我想学习舞蹈(/doge)和瑜伽 ,要无水印的那种有助于我加深学习. 1.组件效果展示 2.组件引入准备 h ...

  7. 基于pyQt5开发的股价显示器(原创)

    #/usr/bin/env python # -*- coding: utf-8 -*- ''' @author="livermorium116" 为了绕开公司内网而开发的 股票实 ...

  8. 基于PyQt5的Python-Gui开发

    环境搭建 电脑环境 win10 64位系统 Python3.5安装 从Python官网下载python3.5安装文件,选择windows 64位版本python-3.6.5-amd64.exe.双击安 ...

  9. 基于pyqt5的图片素材批量处理工具

    功能 分辨率的批量转换,文件夹递归查找 像素偏移量批量调整,文件夹单层查找 画布的大小的批量进行调整,不进行缩放,文件夹单层查找 界面 通过PyUIC生成的代码 # -*- coding: utf-8 ...

随机推荐

  1. vue-i18n 国际化语言切换

    vue-i18n 用于前端vue项目中,需要多语言切换的场景 安装方法(npm) npm install vue-i18n 简单使用   1.在vue项目的main.ts文件中实例化 i18n imp ...

  2. 面试高频题:说一说对Spring和SpringMvc父子容器的理解?

    引言 以前写了几篇关于SpringBoot的文章<面试高频题:springBoot自动装配的原理你能说出来吗>.<保姆级教程,手把手教你实现一个SpringBoot的starter& ...

  3. C# .NET Socket 简单实用框架,socket组件封装

    参考资料 https://www.cnblogs.com/coldairarrow/p/7501645.html 根据.NET Socket 简单实用框架进行了改造,这个代码对socket通信封装还是 ...

  4. kubernetes dashboard 2.0 部署

    dashboard 可以从微软中国提供的 gcr.io :http://mirror.azure.cn/help/gcr-proxy-cache.html免费代理下载被墙的镜像 docker pull ...

  5. 从 lite-apiserver 看 SuperEdge 边缘节点自治

    引言 在 SuperEdge 0.2.0版本中,lite-apiserver 进行了重大的架构升级和功能增强.本文将从 lite-apiserver 实现及其与其它 SuperEdge 组件协同的角度 ...

  6. Dynamics Crm Plugin插件注册的问题及解决方案(持续更新。。。。。。)

    1.注册插件的时候回遇到如下提示 Plug-in assembly does not contain the required types or assembly content cannot be ...

  7. 通过Dapr实现一个简单的基于.net的微服务电商系统(三)——一步一步教你如何撸Dapr

    目录:一.通过Dapr实现一个简单的基于.net的微服务电商系统 二.通过Dapr实现一个简单的基于.net的微服务电商系统(二)--通讯框架讲解 三.通过Dapr实现一个简单的基于.net的微服务电 ...

  8. java面试一日一题:请讲下对mysql的理解

    问题:请讲下对mysql的理解 分析:该问题主要考察对mysql的理解,基本概念及sql的执行流程 回答要点: 主要从以下几点去考虑, 1.mysql的整体架构? 2.mysql中每一个组件的作用? ...

  9. Nginx的进程管理与重载原理

    目录 进程结构图 信号量管理 Linux的信号量管理机制 利用信号量管理Nginx进程 配置文件重载原理 进程结构图 Nginx是多进程结构,多进程结构设计是为了保证Nginx的高可用高可靠,包含: ...

  10. java多种文件复制方式以及效率比较

    1.背景 java复制文件的方式其实有很多种,可以分为 传统的字节流读写复制FileInputStream,FileOutputStream,BufferedInputStream,BufferedO ...