【办公类-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常见环境管理工具超全解析

《python常见环境管理工具超全解析》在Python开发中,管理多个项目及其依赖项通常是一个挑战,下面:本文主要介绍python常见环境管理工具的相关资料,文中通过代码介绍的非常详细,需要的朋友... 目录1. conda2. pip3. uvuv 工具自动创建和管理环境的特点4. setup.py5.

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Python虚拟环境与Conda使用指南分享

《Python虚拟环境与Conda使用指南分享》:本文主要介绍Python虚拟环境与Conda使用指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python 虚拟环境概述1.1 什么是虚拟环境1.2 为什么需要虚拟环境二、Python 内置的虚拟环境工具

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Python pip下载包及所有依赖到指定文件夹的步骤说明

《Pythonpip下载包及所有依赖到指定文件夹的步骤说明》为了方便开发和部署,我们常常需要将Python项目所依赖的第三方包导出到本地文件夹中,:本文主要介绍Pythonpip下载包及所有依... 目录步骤说明命令格式示例参数说明离线安装方法注意事项总结要使用pip下载包及其所有依赖到指定文件夹,请按照以

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1