【办公类-16-07-02】“2023下学期 周计划-户外游戏 每班1周五天相同场地,6周一次循环”(python 排班表系列)

背景需求:

又到了开学季,新的自主游戏(户外游戏)安排表出炉了。

这张是贴在美术活动室的安排表,我需要转换成班级为单位的安排表,便于批量制作周计划。

设计思路:

1、一个班级每周轮到的一个场地,并连续5天(周一到周五):

如中2班第1周轮到美术游戏,就是第1周周一、周二、周三、周四、周五都是玩美术游戏,也就是说每个班级每周去一个场地,并玩5天,(以前的游戏都是每个班级每周轮流5个场地,因此这份代码与过去的代码有较大调整)

2、总部中班有6个班级,并有6种不同的户外游戏场地

从中2班开始,每个班级每周轮到一个不同的游戏场地(1个场地玩5天),第二周从中3班开始,每个班级每周轮到一个不同的游戏场地(1个场地玩5天)……

3、周次是每6周循环,19周就是3次循环+1周

周次显示,第1-6周内每个班级按照斜线轮换的方式进行场地滚动,6个班级6个场地循环36次后,又恢复到中2班为始的状态。

我使用原来的大班游戏活动安排表,发现并不能直接使用,

【办公类-16-05-03】“2022下学期 大班游戏活动室排班表——班主任版20周”(python 排班表系列)_游戏排班-CSDN博客文章浏览阅读90次。【办公类-16-05-03】“2022下学期 大班游戏活动室排班表——班主任版20周”(python 排班表系列)_游戏排班https://blog.csdn.net/reasonsummer/article/details/129094382

通过修改原来的代码,我花了一天做出了想要的结果。

代码展示:


#20230217 '''
2023学年下学期中班户外游戏安排(6个班级 每周玩一个场地5天,第二周轮换 不跳节日)
作者:阿夏
时间:2024年2月19日
'''# import sys
# sys.path.append('/path/to/openpyxl')import sys
import random
import xlrd
import xlwt
from openpyxl import load_workbookimport timetime.sleep(2)# '''班主任贴周计划用的(按班级分类)'''
weekweek=19
# int(input('共有几周?(如19周 20)\n'))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())
# ['2','3','4','5','6','7']
print(len(gradenum))# 8L=[]# 班级
L1=[]
L3=[]  
L2=[]
L4=[]
# 这里是8个活动室游戏活动室,因为后面有递进,所以把最后一个 08,放到01前面,这样摆放后面才会正确)
# L3=['美术游戏','角色游戏','建构游戏','表演游戏','沙水游戏','角色游戏']原始
L3=gradenum# 生成8个班级8组活动室(第1个元素不同)
for i in range(0,len(gradenum)):        # b = L3.pop(0)    # 在活动室游戏活动室列表L3中 删除 第1个元素 大1班 先删除08,就是从01开始L3.append(b)  # 在活动室游戏活动室列表L3最后 添加 第1个元素# print(L[0])L1.append(L3[0:len(gradenum)])     # 把不断变化的内容添加到L1 # 8个班级游戏活动室“基本元素“构成了L1列表:[['01', '02', '03', '04', '05', '06', '07', '08'], ['02', '03', '04', '05', '06', '07', '08', '01'], ['03', '04', '05', '06', '07', '08', '01', '02'], ['04', '05', '06', '07', '08', '01', '02', '03'], ['05', '06',  
# print(L1)# 每周6个班级,基础模板6次 L=班级
for b in range(4):        # 把各班“游戏活动室基本元素8个”循环21次,数量多一点,便于后期提取内容for y in L1:for z in y:    #抽取L1中的一组组内容  L1[0]=['01', '02', '03', '04', '05', '06', '07', '08']、L1[1]=['02', '03', '04', '05', '06', '07', '08', '01'],# 在用 y提取L1[0]中的'01', '02', '03', '04', '05', '06', '07', '08'三个元素L.append(z)     #把y提取的单个元素一个个加到列表里,并且依次循环22次,数量足够多
# print(L)
# 144
# print(len(L))
#    ['中2班', '中3班', '中4班', '中5班', '中6班', '中7班', '中3班', '中4班', '中5班', '中6班', '中7班', '中2班', '中4班', '中5班', '中6班', '中7班', '中2班', '中3班', '中5班', '中6班', '中7班', '中2班', '中3班', '中4班', '中6班', '中7班', '中2班', '中3班', '中4班', '中5班', '中7班', '中2班', '中3班', '中4班', '中5班', '中6班', '中2班', '中3班', '中4班', '中5班', '中6班', '中7班', '中3班', '中4班', '中
# 5班', '中6班', '中7班', '中2班', '中4班', '中5班', '中6班', '中7班', '中2班', '中3班', '中5班', '中6班', '中7班', '中2班', '中3班', '中4班', '中6班', '中7班', '中2班', '中3班', '中4班', '中5班', '中7 
# 班', '中2班', '中3班', '中4班', '中5班', '中6班', '中2班', '中3班', '中4班', '中5班', '中6班', '中7班', '中3班', '中4班', '中5班', '中6班', '中7班', '中2班', '中4班', '中5班', '中6班', '中7班', '中2班
# ', '中3班', '中5班', '中6班', '中7班', '中2班', '中3班', '中4班', '中6班', '中7班', '中2班', '中3班', '中4班', '中5班', '中7班', '中2班', '中3班', '中4班', '中5班', '中6班', '中2班', '中3班', '中4班', '中5班', '中6班', '中7班', '中3班', '中4班', '中5班', '中6班', '中7班', '中2班', '中4班', '中5班', '中6班', '中7班', '中2班', '中3班', '中5班', '中6班', '中7班', '中2班', '中3班', '中4班', '中6班', '中7班', '中2班', '中3班', '中4班', '中5班', '中7班', '中2班', '中3班', '中4班', '中5班', '中6班']# 10print('---------第2步:六类游戏乘以19周------')  
L4=['美术游戏','角色游戏','建构游戏','表演游戏','沙水游戏','角色游戏']
L5=[]
for v in range(weekweek):        # 19周a        for w in L4:for l in range(5):# 美术游戏中1班一周玩5次,角色L5.append(w)
# print(L5)
# print(len(L5))
# # 570/5=114#     print('---------第2步:如果一周有5天(不考虑跳过假日)------')#     print('{}'.format(gradenum[num]))# 限制19周的     
for i in range(0,int(len(L5)/5)):#第1周L2.append(L5[i*5:i*5+5])
# print(L2)
# print(len(L2))
# 114
# L2=角色游戏等6类游戏的嵌套列表# # #     # print('---------第3步:如果每周需要跳过假日(考虑跳过假日)------')# # #     # #  每周需要的天数 (跳过节日.如第1周只有2天工作,9月1-2日(周四周五) ,第3周周一是中秋节放假1天,所以只有4个工作日)
# # #     # day=['2','5','4','5','5','2','5','5','5','5','5','5','5','5','5','5','5','4','5','5','2']# # #     # print('中{}班'.format(gradenum[num]))
# # #     # # 第1周
# # #     # for d in range(0,1):          # d=索引数字
# # #     #     print(L[0:int(day[0])]) # 列表有8个活动室项目,但只要其中5个(周一到周五)
# # #     #     L2.append(L[0:int(day[0])]) 
# # #     # # 第2周开始
# # #     # for d in range(1,len(day)):        # 0-21
# # #     #     # print(d+1)
# # #     #     L=L[int(day[d-1]):]  # day[0]=2,
# # #     #     L.append(L) # 将a安排到最后一个座位
# # #     #     print(L[0:int(day[d])])# 列表是八个循环,我只要其中5个
# # #     #     L2.append(L[0:int(day[d])])# # #     # 以下是跳过假日的最初的写法,太长了,研究上面的是2022.9.9-2023.1.17 共21周的假日安排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=0
for 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(L4)):n="第{}周".format('%02d'%i)    # 用遍历方法获得“第1周、第2周、第21周”字样,dates.append(n)          # 添加到列表    s
print(dates)  
print(len(dates))  
#114 # 写入周次
row=1
for d in range(0, len(dates)):sheet.write(row, 1, dates[d])         # 这里enumerate不能用,因为只有一列,所以就用row += 1    print('---------第4-3步:第1列写入班级)------') 
# 写入班级列 L=班级列
row=1
for h in range(0, len(L[:len(dates)])):        # 只要班级列表的前114个        sheet.write(row,0,L[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\桌面\周计划\20240218 下学期中班户外游戏一周五天相同(班主任用).xls")    # 新建保存 只能xlsprint('计划生成成功')
except e:print('失败...')print(e)# print('---------第6步:把1份xls按照班级,分类成N个不同的工作表内(班主任贴周计划用)------')      
# https://blog.csdn.net/xo3ylAF9kGs/article/details/135856653# 切割成同表
import pandas as pd
import osdf = pd.read_excel(r'C:\Users\jg2yXRZ\OneDrive\桌面\周计划\20240218 下学期中班户外游戏一周五天相同(班主任用).xls')writer = pd.ExcelWriter(r'C:\Users\jg2yXRZ\OneDrive\桌面\周计划\20240218 下学期中班户外游戏一周五天相同(班主任用).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()

运行结果

分表:

1、6周一次循环

2、便于班主任了解本周户外游戏场地+便于制作周计划

3、能够验证正确性

重点说明:

我一直很困扰:如何让一张EXCEL总表按照“班级”拆分成多个表格(在一个EXCEL内),

以下是解决方案,包含拆分多个工作簿(不在一个EXCEL内)和拆分多个工作表(在一个EXCEL内),非常实用 ,强烈推荐

Python实现Excel拆分与合并-CSDN博客文章浏览阅读23次。在实际工作中,我们经常会遇到各种表格的拆分与合并的情况。如果只是少量表,手动操作还算可行,但是如果是几十上百张表,最好使用Python编程进行自动化处理。下面介绍两种拆分案例场景,如何用Pandas实现Excel文件的拆分。按条件将Excel文件拆分到不同的工作簿假设现在有一个汇总表,内部存储了整个年级的成绩数据。现在需要按照班级分类,将不同班级的数据拆分到不同的工作簿中,最终实现"三年级总成绩...https://blog.csdn.net/xo3ylAF9kGs/article/details/135856653

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/478220.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

通过VSCode开发Python项目

一、插件准备 Python 插件,必须 autoDocstring 生成注释,和Pycharm一样输入三个引号"""会生产注释结构 Todo Tree 高亮显示 TODO/FIXME 二、python相关设置 一)设置python环境 按"F1"打开命令面板(…

嵌入式 系统 开发 - 第一件事 “搭开发环境”

无论是对DSP,FPGA,或其他可编程芯片开发 都要 “搭开发环境” : 懒得写太多字,画个图来扯淡吧! 看看实际 怎么搞的 :) 这张照片仅仅是 老哥 自己的一个DSP开发实际连结的搞法儿啊&#xff0c…

电脑数据丢失怎么办?5 种免费数据恢复软件能帮到您

我们存储在计算机中的个人和专业数据如果丢失,可能会给我们带来经济和精神上的困扰。有许多情况会导致此类数据丢失;其中一些包括意外删除、硬盘驱动器故障、软件崩溃、病毒攻击等。 5 种最佳免费数据恢复软件 为防止此类事故,建议定期备份计…

Kubernetes基础(二十二)-k8s持久化存储详解

1 volume 1.1 介绍 在容器中的磁盘文件是短暂的,当容器崩溃时,Kubelet会重新启动容器,但容器运行时产生的数据文件都将会丢失,之后容器会以最干净的状态启动。另外,当一个Pod运行多个容器时,各个容器可能…

http相关概念以及apache的功能

概念 互联网:是网络的网络,是所有类型网络的母集 因特网:世界上最大的互联网网络 万维网:www (不是网络,而是数据库)是网页与网页之间的跳转关系 URL:万维网使用统一资源定位符,…

正整数A+B(PTA团体天题练习题)细节题刨析

哎呀,又是看似简单的AB模型,这题确实也是AB,不过这个题让我debug1个多小时才找出来问题所在,服了,真是所谓细节决定成败,这题也挺值得记录下来的,话不多嗦,看题 题的目标很简单&…

【深入理解设计模式】单例设计模式

单例设计模式 概念: 单例模式(Singleton Pattern)是 Java 中最简单的设计模式之一。 单例设计模式是一种创建型设计模式,其主要目的是确保类在应用程序中的一个实例只有一个。这意味着无论在应用程序的哪个位置请求该类的实例&a…

左右联动布局效果

效果图&#xff1a; <template><el-dialog :modelValue"modelValue" :before-close"close" fullscreen :close-on-click-modal"false"><div class"farmer_detail"><div class"info_content"><di…

数论 - 高斯消元

文章目录 一、高斯消元解线性方程组1.题目描述输入格式输出格式数据范围输入样例&#xff1a;输出样例&#xff1a; 2.算法思路3.代码 二、高斯消元解异或线性方程组1.题目描述输入格式输出格式数据范围输入样例&#xff1a;输出样例&#xff1a; 2.算法思路3.代码 数学上&…

微信小程序swiper 视频中间大,两边小,轮播滑到中间视频自动播放组件教程

静态效果&#xff1a; 进入下面小程序可以体验效果&#xff0c;点击底部 看剧 栏目 一、创建小程序组件 二、代码 1、WXML <view class"swiper-wrapper" style"background-image:url(/asset/image/hot-banner.jpg);background-size: 100% 100%;">…

USB-C音频转接器:实现边充电边听歌的新选择 | LDR6020P

随着科技浪潮的推进&#xff0c;Type-C接口已逐渐成为电子设备的主流选择&#xff0c;以其正反随意插、高速传输和强大功能等独特优势&#xff0c;在日常生活中占据越来越重要的地位。而Type-C音频转接器&#xff0c;作为连接Type-C接口与音频设备的桥梁&#xff0c;正引领着音…

appium实现自动化测试原理

目录 1、Appium原理 1.1、Android Appium原理图文解析 1.1.2、原理详解 1.1.2.1、脚本端 1.1.2.2、appium-server 1.1.2.3、中间件bootstrap.jar 1.1.2.4、驱动引擎uiautomator 1.2、 IOS Appium原理 1、Appium原理 1.1、Android Appium原理图文解析 执行测试脚本全过…