【办公类-16-07-07】“2023下学期 大班户外游戏2(有场地和无场地版,每天不同场地)”(python 排班表系列)

本文主要是介绍【办公类-16-07-07】“2023下学期 大班户外游戏2(有场地和无场地版,每天不同场地)”(python 排班表系列),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作品展示

背景需求:

2024年2月教务组发放的是“每周五天内容相同,两周10天内容相同”的户外游戏安排

【办公类-16-07-05】合并版“2023下学期 大班户外游戏(有场地和无场地版,两周一次)”(python 排班表系列)-CSDN博客文章浏览阅读450次,点赞6次,收藏5次。【办公类-16-07-05】合并版“2023下学期 大班户外游戏(有场地和无场地版,两周一次)”(python 排班表系列)https://blog.csdn.net/reasonsummer/article/details/136197861

教学环节不断动态优化,2024年3月教务组又改了户外游戏安排。o(╥﹏╥)o

所以又要重新做一份“有场地”(贴墙实际操作版)和“无场地(贴会周计划)版本”

素材准备:

新的中班户外游戏安排表内容

这张表看起来,相当繁琐,

1、表格阅读繁琐

本次表格在实际使用中查看非常麻烦,如果需要先找到第4周(翻到第5张表),然后查看左侧的星期列,找到星期三,然后横向向右去查看中4班在那个位置,顺着中4班级格子向上查看是什么项目(表演游戏),然后把文档翻到最下面备注,查看场地。

因此,我努力把它“”翻译“成班级用的EXCEL。

2、转换成横排模式,突出游戏场地

以前的星期都是横排的,班级在左侧列,活动场地分布在X-Y的矩阵内。因此我想将第一周表格转换成以下样式,来确定“游戏场地”的分布情况

从第1周看,这次的场地是【12345,】,【61234】,【56123】的移动方式。从第2周看,第2周的中2的五天内容与第1周的中3内容相同。

因此代码修改如下:

'''
中班6个班级
2023学年下学期中班户外游戏安排_有场地和无场地 两个版本
(6个班级 每周每天换一个场地5天,)
作者:阿夏
时间:2024年3月20日
'''# import sys
# sys.path.append('/path/to/openpyxl')import sys
import random
import xlrd
import xlwt
from openpyxl import load_workbookimport time# '''班主任贴周计划用的(按班级分类)'''
weekweek=19
# int(input('共有几周?(如19周 20)\n'))
# aaa=int(input('1、需要场地、2、不要场地\n'))for aaa in [1,2]:print('---------第1步:制作每个班级的游戏的总表------')# 本学期:中1,中2,中3,中4,中5,中7,中8,中9班,其中6班空缺,一共有8个中班gradenum=[]for g in range(2,8):gradenum.append('中{}班'.format(g))print(gradenum)# gradenum.insert(0, gradenum.pop())print(len(gradenum))#     # # ['2','3','4','5','6','7']L8=[]# 班级数列for b in range(19):for d in gradenum:        L8.append(d)print(L8)print(len(L8))# 制作19*5*6个元素,以便替换(备注)内容L1=[]# 班级for b in range(19):for d in gradenum:for c in range(5):L1.append(d)print(L1)print(len(L1))# 570# # print('---------第2步:制作六类游戏的五天列表------')  ts =19*5L=[]# 班级L11=[]L3=[]  L2=[]L4=[]# 这里是8个活动室游戏活动室,因为后面有递进,所以把最后一个 08,放到01前面,这样摆放后面才会正确)L3=['美术游戏(滑梯)','角色游戏','沙水游戏(中庭)','表演游戏','建构游戏(三楼露台)','角色游戏',]# 将1移动到5的后面L3.append(L3.pop(0))# 循环提取,获得5天一组的基础L11=[]for i in range(6):# 将5移动到1的前面L3.insert(0, L3.pop())# print(L3)L11.append(L3[0:5])# print(L11)# ['美术游戏(滑梯)', '角色游戏', '沙水游戏(中庭)', '表演游戏', '建构游戏(三楼露台)']# ['角色游戏', '美术游戏(滑梯)', '角色游戏', '沙水游戏(中庭)', '表演游戏']# ['建构游戏(三楼露台)', '角色游戏', '美术游戏(滑梯)', '角色游戏', '沙水游戏(中庭)']# ['表演游戏', '建构游戏(三楼露台)', '角色游戏', '美术游戏(滑梯)', '角色游戏']# ['沙水游戏(中庭)', '表演游戏', '建构游戏(三楼露台)', '角色游戏', '美术游戏(滑梯)']# ['角色游戏', '沙水游戏(中庭)', '表演游戏', '建构游戏(三楼露台)', '角色游戏']# 6种基本形体,遍历20次L12=[]for o1 in range(20):for o2 in L11:        L12.append(o2)# print(L12)# print(len(L12))# 120L13=[]for i in range(19):# 将5移动到1的前面L13.append(L12[i:i+6])print(L13)L6=[] for b1 in L13:for b2 in b1: for b3 in b2:L6.append(b3)print(L6)print(len(L6))# # 根据班级,增加角色、表演旁边的场地# # 中2班角色游戏、表演游戏场地——树屋                         中3班角色游戏、表演游戏场地——小农场# # 中4班角色游戏、表演游戏场地——中1班南门口                 中5班角色游戏、表演游戏场地——中3班南门口# # 中6班角色游戏、表演游戏场地——天台                         中7班角色游戏、表演游戏场地——天台L5=[]coom=['2','3','4','5','6','7']room=['树屋','小农场','大1班南门','大3班南门','天台','天台',]print(len(L1))print(len(L6))for cc in range(len(L6)):    if L6[cc]=='角色游戏' or L6[cc]=='表演游戏': # print(L6[cc])         for kk in range(len(room)) :if L1[cc]=='中{}班'.format(coom[kk]) :L5.append('{}({})'.format(L6[cc],room[kk])) else:L5.append(L6[cc])print(L5)print(len(L5))L7=[]for ff in L5:if aaa==1:L7.append(ff)        # 美术活动(操场)if aaa==2:L7.append(ff[:4])      # 美术活动print(L7)print(len(L7))# 570/5=114# #     print('---------第2步:如果一周有5天(不考虑跳过假日)------')# 限制19周的     for j in range(0,int(len(L7)/5)):#第1周L2.append(L7[j*5:j*5+5])print(L2)print(len(L2))    print('---------第4-1步:xls写入)------') workbook = xlwt.Workbook()# 新建xls工作簿sheet = workbook.add_sheet("Sheet")# 新建xls工作簿的工作表的名字是sheet print('---------第4-2步:第1行 写入 星期一等)------')    weeks = ['班级','周次','星期一','星期二','星期三','星期四','星期五',]# weeks=['周次','美术游戏','角色游戏','建构游戏','表演游戏','沙水游戏','角色游戏']week = len(weeks) col=0for d in range(0, len(weeks)):sheet.write(0,col,weeks[d])         # 因为只有一行,所以就用有两种写法(enumerate和这种)col+= 1 print('---------第4-3步:第2列写入周次)------')    # 第0列 写入“第1周、第2周、第3周……第21周dates=[]# 制作第一列的所有文字for i in range(1,int(weekweek+1)):for r in range(len(gradenum)):n="第{}周".format('%02d'%i)    # 用遍历方法获得“第1周、第2周、第21周”字样,dates.append(n)          # 添加到列表    sprint(dates)  print(len(dates))  #114 # 写入周次row=1for d in range(0, len(dates)):sheet.write(row, 1, dates[d])         # 这里enumerate不能用,因为只有一列,所以就用row += 1    print('---------第4-3步:第1列写入班级)------') # 写入班级列 L=班级列row=1for h in range(0, len(L8[:len(dates)])):        # 只要班级列表的前114个        sheet.write(row,0,L8[h])         # 因为只有一行,所以就用有两种写法(enumerate和这种)row += 1      print('---------第4-5步:第3-9列写入游戏内容一周五次相同)------') row=1    #  写入游戏内容列 L2=游戏内容一周五个for i in range((len(L2))):         # 遍历21组[]的总数for col,item in enumerate(L2[i],2):            # L2[i]=表格内的内容=item,索引数字=colsheet.write(row,col,item)  # row,col,item 行=1、列=索引数字、内容=表格内容 写入第一行第一列row += 1 #print('---------第5步:xls保存N份工作簿(每份一页)------')             try:workbook.save(r"C:\Users\jg2yXRZ\OneDrive\桌面\周计划\测试.xls")    # 新建保存 只能xlsprint('计划生成成功')except e:print('失败...')print(e)# print('---------第6步:把1份xls按照班级,分类成N个不同的工作表内(班主任贴周计划用)------')      # https://blog.csdn.net/xo3ylAF9kGs/article/details/135856653# 切割成同表import pandas as pdimport osdf = pd.read_excel(r'C:\Users\jg2yXRZ\OneDrive\桌面\周计划\测试.xls')if aaa==1:writer = pd.ExcelWriter(r'C:\Users\jg2yXRZ\OneDrive\桌面\周计划\20240310 下学期中班户外游戏一周五天不同区域有场地(班主任用).xls')if aaa==2:writer = pd.ExcelWriter(r'C:\Users\jg2yXRZ\OneDrive\桌面\周计划\20240310 下学期中班户外游戏一周五天不同区域无场地(班主任用).xls')df.to_excel(writer, sheet_name='Sheet', index=False)for j in df['班级'].unique():df[df['班级'] == j].to_excel(writer, sheet_name=j+'户外游戏', index=False)writer.save()# # 删除过渡EXCLE
os.remove(r'C:\Users\jg2yXRZ\OneDrive\桌面\周计划\测试.xls')

感悟:

一、通过Python程序,将户外游戏安排表(总表)上的内容,转换为班本化的,可以实现:

1、标明各班每周每天的户外游戏内容(场地),便于班主任快速查看操作

2、制作无场地的户外游戏表,便于黏贴周计划。

二、更迅速应对工作中的“反复”,调整心态。

有了程序,在面对“上级”的“课(fan)程(fu)优(wu)化(chang),我就能多一些控制感,少一些抱怨,快速适应变化。

这篇关于【办公类-16-07-07】“2023下学期 大班户外游戏2(有场地和无场地版,每天不同场地)”(python 排班表系列)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/832113

相关文章

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Python实现快速扫描目标主机的开放端口和服务

《Python实现快速扫描目标主机的开放端口和服务》这篇文章主要为大家详细介绍了如何使用Python编写一个功能强大的端口扫描器脚本,实现快速扫描目标主机的开放端口和服务,感兴趣的小伙伴可以了解下... 目录功能介绍场景应用1. 网络安全审计2. 系统管理维护3. 网络故障排查4. 合规性检查报错处理1.

Python轻松实现Word到Markdown的转换

《Python轻松实现Word到Markdown的转换》在文档管理、内容发布等场景中,将Word转换为Markdown格式是常见需求,本文将介绍如何使用FreeSpire.DocforPython实现... 目录一、工具简介二、核心转换实现1. 基础单文件转换2. 批量转换Word文件三、工具特性分析优点局

Python中4大日志记录库比较的终极PK

《Python中4大日志记录库比较的终极PK》日志记录框架是一种工具,可帮助您标准化应用程序中的日志记录过程,:本文主要介绍Python中4大日志记录库比较的相关资料,文中通过代码介绍的非常详细,... 目录一、logging库1、优点2、缺点二、LogAid库三、Loguru库四、Structlogphp

C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解

《C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解》:本文主要介绍C++,C#,Rust,Go,Java,Python,JavaScript性能对比全面... 目录编程语言性能对比、核心优势与最佳使用场景性能对比表格C++C#RustGoJavapythonjav

Python海象运算符:=的具体实现

《Python海象运算符:=的具体实现》海象运算符又称​​赋值表达式,Python3.8后可用,其核心设计是在表达式内部完成变量赋值并返回该值,从而简化代码逻辑,下面就来详细的介绍一下如何使用,感兴趣... 目录简介​​条件判断优化循环控制简化​推导式高效计算​正则匹配与数据提取​性能对比简介海象运算符

python项目环境切换的几种实现方式

《python项目环境切换的几种实现方式》本文主要介绍了python项目环境切换的几种实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 如何在不同python项目中,安装不同的依赖2. 如何切换到不同项目的工作空间3.创建项目

python项目打包成docker容器镜像的两种方法实现

《python项目打包成docker容器镜像的两种方法实现》本文介绍两种将Python项目打包为Docker镜像的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录简单版:(一次成功,后续下载对应的软件依赖)第一步:肯定是构建dockerfile,如下:第二步

Python + Streamlit项目部署方案超详细教程(非Docker版)

《Python+Streamlit项目部署方案超详细教程(非Docker版)》Streamlit是一款强大的Python框架,专为机器学习及数据可视化打造,:本文主要介绍Python+St... 目录一、针对 Alibaba Cloud linux/Centos 系统的完整部署方案1. 服务器基础配置(阿里