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

news2025/1/12 1:04:47

作品展示——有场地说明

背景需求:

前期做了一份“贴周计划”用的班主任版的户外游戏安排表(中X班19周,没有场地)

【办公类-16-07-02】“2023下学期 周计划-户外游戏 每班1周五天相同场地,6周一次循环”(python 排班表系列)-CSDN博客文章浏览阅读739次,点赞11次,收藏21次。【办公类-16-07-02】“2023下学期 周计划-户外游戏 每班1周五天相同场地,6周一次循环”(python 排班表系列)https://blog.csdn.net/reasonsummer/article/details/136176883

但是这份游戏表中对于“场地”有要求,因此实际日常操作中,每个班级需要看备注,才能知道自己班级的场地,

为了便于班主任知道自己班级每一天的户外游戏场地在哪里,我想在”美术游戏“后面加上”(场地),并对”角色游戏2套“”表演游戏“中的6个班级进行不同的场所备注。

代码展示:


#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_workbook

import time



# '''班主任贴周计划用的(按班级分类)'''
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))# 8


L=[]# 班级
L1=[]
L3=[]  
L2=[]
L4=[]
# 这里是8个活动室游戏活动室,因为后面有递进,所以把最后一个 08,放到01前面,这样摆放后面才会正确)
# L3=['美术游戏','角色游戏','建构游戏','表演游戏','沙水游戏','角色游戏']原始
L3=gradenum

# 生成6个班级(第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)
# [['中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班']]
print(len(L1))
# 6组基本    

# 每周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)
# #    ['中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班']
print(len(L))
# # 6组基本变出 144个班级,最后只要114个班级

    
# print('---------第2步:六类游戏乘以19周(只有一个)------')  
L4=['美术游戏(滑梯)','角色游戏','建构游戏(三楼露台)','表演游戏','沙水游戏(中庭)','角色游戏']
L6=[]
for v in range(weekweek):        # 19周a        
    for w in L4:
        # for l in range(5):# 美术游戏中1班一周玩5次,角色
            L6.append(w)
print(L6)
print(len(L6))
# 114

# 根据班级,增加角色、表演旁边的场地
# 中2班角色游戏、表演游戏场地——树屋                         中3班角色游戏、表演游戏场地——小农场
# 中4班角色游戏、表演游戏场地——大1班南门口                 中5班角色游戏、表演游戏场地——大3班南门口
# 中6班角色游戏、表演游戏场地——天台                         中7班角色游戏、表演游戏场地——天台

# a=len(room)
# 6

L5=[]
# coom=['2','3','4','5','6','7']
coom=['2','3','4','5','6','7']
room=['树屋','小农场','大1班南门','大3班南门','天台','天台',]

for cc in range(len(L6)):    
    if L6[cc]=='角色游戏' or L6[cc]=='表演游戏':          
        for kk in range(len(room)) :
            if L[cc]=='中{}班'.format(coom[kk]) :
                L5.append('{}({})'.format(L6[cc],room[kk]))  
        # if L[cc]=='中2班' :
        #     L5.append('{}(树屋)'.format(L6[cc]))
        # if L[cc]=='中3班' :
        #     L5.append('{}(小农场)'.format(L6[cc]))    
        # if L[cc]=='中4班' :
        #     L5.append('{}(大1班南门)'.format(L6[cc]))  
        # if L[cc]=='中5班' :
        #     L5.append('{}(大3班南门)'.format(L6[cc]))  
        # if L[cc]=='中6班' :
        #     L5.append('{}(天台)'.format(L6[cc]))  
        # if L[cc]=='中7班':
        #     L5.append('{}(天台)'.format(L6[cc]))  
          
        #  
    
    else:
        L5.append(L6[cc])
        # L5.append(L6[cc])
print(L5)
print(len(L5))
# 240


L7=[]

for ff in L5:
    for ww in range(5):
        L7.append(ff)
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))
# 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,索引数字=col
        sheet.write(row,col,item)  # row,col,item 行=1、列=索引数字、内容=表格内容 写入第一行第一列
    row += 1 
#
        

print('---------第5步:xls保存N份工作簿(每份一页)------')             
try:
    workbook.save(r"C:\Users\jg2yXRZ\OneDrive\桌面\周计划\20240218 下学期中班户外游戏一周五天相同有场地(班主任用).xls")    # 新建保存 只能xls
    print('计划生成成功')
except e:
    print('失败...')
    print(e)

# print('---------第6步:把1份xls按照班级,分类成N个不同的工作表内(班主任贴周计划用)------')      
# https://blog.csdn.net/xo3ylAF9kGs/article/details/135856653

# 切割成同表
import pandas as pd
import os
 
df = 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()

不同班级不同的户外游戏内容及不同的场地。

全选下方的白色标签,然后批量制作标题抬头,把内容控制在A4一页内,便于打印

贴在墙上

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

击败.helper勒索病毒:恢复被加密的数据文件的方法

导言: 近年来,勒索病毒成为网络安全领域的一大威胁,其中.helper勒索病毒更是备受关注。该类型的勒索软件以其高效的加密算法,能够将用户的文件加密,迫使用户支付赎金才能解密数据。本文将介绍.helper勒索病毒的特点、恢复被加密数…

unity学习(30)——跳转到角色选择界面(跳转新场景)

1.在scene文件夹中([siːn]),右键->create->scene,名字叫SelectMenu(选择角色场景)。 2.把新建场景拖拽到hierarchy[ˈhaɪərɑːki]中。 3.此时才能在file->build setting中Add open scene&…

vue页面基本增删改查

练手项目vue页面 新手前端轻喷: 效果如下 1、2两个部分组成: 对应代码中 element-ui中的 el-form 和 el-table 照着抄呗,硬着头皮来! 建议:认真读一遍你用的组件 这篇文章烂尾了,对不起大家

MySQL安装教程(详细版)

今天分享的是Win10系统下MySQL的安装教程,打开MySQL官网,按步骤走呀~ 宝们安装MySQL后,需要简单回顾一下关系型数据库的介绍与历史(History of DataBase) 和 常见关系型数据库产品介绍 呀,后面就会进入正式…

计算机视觉基础:【矩阵】矩阵选取子集

OpenCV的基础是处理图像,而图像的基础是矩阵。 因此,如何使用好矩阵是非常关键的。 下面我们通过一个具体的实例来展示如何通过Python和OpenCV对矩阵进行操作,从而更好地实现对图像的处理。 示例 示例:选取矩阵中指定的行和列的…

总结Rabbitmq的六种模式

RabbitMQ六种工作模式 RabbitMQ是由erlang语言开发,基于AMQP(Advanced Message Queue 高级消息队列协议)协议实现的消息队列,它是一种应用程序之间的通信方法,消息队列在分布式系统开发中应用非常广泛。 RabbitMQ有六…

请介绍一下美国德克萨斯州历史地理与环境经济文化与社会教育与科研结论请介绍一下罗格斯大学(Rutgers University)校园与分校学术项目研究与创新学

目录 请介绍一下美国德克萨斯州 历史 地理与环境 经济 文化与社会 教育与科研 结论 请介绍一下罗格斯大学(Rutgers University) 校园与分校 学术项目 研究与创新 学生生活 社会贡献 请介绍一下德州A&M大学系统 组成成员 教育与研究 …

板块一 Servlet编程:第六节 HttpSession对象全解 来自【汤米尼克的JAVAEE全套教程专栏】

板块一 Servlet编程:第六节 HttpSession对象全解 一、什么是HttpSessionSession的本质 二、创建Seesion及常用方法三、Session域对象四、Session对象的销毁 在上一节中,我们学习了Servlet五大对象里的第三个Cookie对象,但Cookie是有大小限制和…

关于开放系统互联的一些笔记

最近几天就发几篇计算机方面的基础知识 属于个人归纳整理,便于理解希望对大家有帮助 原文地址:关于开放系统互联的一些笔记 - Pleasure的博客 下面是正文内容: 前言 最近在恶补一些计算机方面的基础知识…… 正文 首先为了能够更透彻的理…

VSCode C/C++无法跳转到定义(又是你 clangd !)

原博客:VSCode C/C无法跳转到定义、自动补全、悬停提示功能_c/c:edit configurations(json)-CSDN博客 我在此基础上加一点: 首先确保自己有这个插件: 点击 齿轮⚙ 符号,进入 配置设置,找到 把 C_cpp : Intelli Sens…

【实现100个unity特效之4】Unity ShaderGraph使用教程与各种特效案例(2023/12/1更新)

文章目录 一、前言二、ShaderGraph1.什么是ShaderGraph2.在使用ShaderGraph时需要注意以下几点:3.优势4.项目 三、实例效果边缘发光进阶:带方向的菲涅尔边缘光效果裁剪进阶 带边缘色的裁剪溶解进阶 带边缘色溶解卡通阴影水波纹积雪效果不锈钢效果、冰晶效…

AR智能眼镜主板硬件设计_AR眼镜光学方案

AR眼镜凭借其通过导航、游戏、聊天、翻译、音乐、电影和拍照等交互方式,将现实与虚拟进行无缝融合的特点,实现了更加沉浸式的体验。然而,要让AR眼镜真正成为便捷实用的智能设备,需要解决一系列技术难题,如显示、散热、…

钉钉小程序无法关联应用

钉钉小程序无法关联应用 problem 后台创建了新的应用钉钉小程序开发者工具>企业内部应用>关联应用 没有下拉列表 无法关联,只能点击新增按钮,重新进入后台很奇怪,明明创建好了应用,为什么关联下拉列表没有这个应用呢&…

在VS里使用C#制作窗口应用

新建项目 创建项目的时候搜索net,选择这个。 打开应该是这样 第一个控件 选择公共控件 - PictureBox - 拖入Form 在Image处选择上传本地资源,建议上传一个小一点的图片。 修改一下尺寸。 ctrls 保存 从“属性”切换到“事件” 双击Click事件…

STM32-开发工具

开发过程中可能用到的工具 1、烧录下载调试工具ST-LINK ST-LINK,是ST(意法半导体)推出的调试编程工具,适用于STM32系列芯片的USB接口的下载及在线仿真器。 2、串口调试工具/串口下载工具 串口调试工具是一种用于通过串口通信协议与目标设备进行数据交…

Linux——进程替换

📘北尘_:个人主页 🌎个人专栏:《Linux操作系统》《经典算法试题 》《C》 《数据结构与算法》 ☀️走在路上,不忘来时的初心 文章目录 一、进程程序替换1、替换原理2、替换函数3、函数解释4、命名理解 二、用例测试1、execl测试2、…

基于多种机器学习模型的西北地区蒸散发模拟与趋势分析_季鹏_2023

基于多种机器学习模型的西北地区蒸散发模拟与趋势分析_季鹏_2023 摘要关键词 1 资料和方法1. 1 研究区域与观测数据1. 2 机器学习模型构建与验证方法1. 3 SHAP 可解释性方法 2 主要结果2. 1 不同模型的模拟性能和泛化能力2. 2 不同模型的可解释性分析2. 3 5 km 分辨率格点蒸散发…

长短期记忆神经网络

目录 LSTM 神经网络架构 分类 LSTM 网络 回归 LSTM 网络 视频分类网络 更深的 LSTM 网络 网络层 分类、预测和预报 序列填充、截断和拆分 按长度对序列排序 填充序列 截断序列 拆分序列 指定填充方向 归一化序列数据 无法放入内存的数据 可视化 LSTM 层架构 …

【Flink状态管理五】Checkpoint的设计与实现

文章目录 1. Checkpoint的整体设计2. Checkpoint创建源码解析2.1. DefaultExecutionGraphBuilder.buildGraph2.2. ExecutionGraph.enableCheckpointing 由于系统原因导致Flink作业无法正常运行的情况非常多,且很多时候都是无法避免的。对于Flink集群来讲&#xff0c…

构造函数,原型,实例,类的关系整理

视频来源js原型链、构造函数和类_哔哩哔哩_bilibili 如视频所说,构造函数的prototype指向原型,实例化的对象的__proto__指向原型,原型通过constructor指向构造函数,正如class里面的constructor方法就相当于Person构造函数一样&am…