【办公类-16-06-02】“2022下学期 总园活动室(沙水+建构)排班表(两周一次沙水)”(python 排班表系列)

news2025/1/11 2:01:23

作品展示:

背景需求:

上一篇批量制作了“7天轮回14班沙水+每周固定建构”的活动室内排班表。

一、时段冲突,调整单双周。

保教主任抽空检查后,提到:“一个班、上午、下午都有自主游戏(沙水、建构、表演、角色)是不对的,通常每天上午一个自主游戏、下午就必须是个别化学习。同理上午是个别化学习,下午就是自主游戏

按原有排序方式,7天轮流沙水与5天建构游戏永远有出现3次重合。不符合排序规律。

我们讨论后,保教主任同意14个班级”2周轮一次沙水(1个沙水活动室),1周轮一次建构(2个建构活动室)“

结论:时间宽裕了,理论上排序更便利。

二、时段信息,详细标注

但是她又提出新的需求。

  1. 时段罗列:各班一周5天表格内需要写成”沙水/个别”“建构/个别”“自主/个别”的形式,前者代表上午场活动,后者代表下午场活动。

  1. 场所写明:涉及到两个建构活动室,最好表明“大班-建构1”“中班-建构2”。

结论:涉及到自主游戏在上午还是下午、涉及到建构1建构2的分配、以及单双周各班可能有单周或双周只有建构没有沙水。需要撰写的样式就变多、变复杂了。

8种列表排序方式(大班4种,中班4种)

首先我把8个大班,均分位4个(大1-4)(大5-8)、6个中班,均分位3个(中3-5)(中6-8)

以建构为先(它是每周固定都有的)大1班建构、沙水排在周一上午、周二上午

以下是各种

这里还是先在纸上推算,然后再一点点调整重选列表对象,花了2个小时才正确的。

代码展示:


#20230217 2022学年下学期大班活动室安排(8个班级 不跳节日)

import sys
import random
import xlrd
import xlwt
from openpyxl import load_workbook
import time

time.sleep(2)
'''班主任贴周计划用的(按班级分类)'''

# weekweek=int(input('共有几周?(如20周 20)\n'))


print('---------第1步:把8个活动室游戏活动室循环21次(105元素组成的列表)------')

# 本学期:大1,大2,大3,大4,大5,大7,大8,大9班,其中6班空缺,一共有8个大班
gradenum=['大1','大2','大3','大4','中3','中4','中5','大5','大7','大8','大9','中6','中7','中8']


L=[]# 这里的L等于list,因为和最后excle合并程序中的代码有冲突,所以全部改成大写的首字母
L1=[]
L3=[]  
L2=[]
L4=[]
# 这里是8个活动室游戏活动室,因为后面有递进,所以把最后一个 08,放到01前面,这样摆放后面才会正确)
# list1=['1','2','3','4','5',]
da11=['建构1/个别','沙水/个别','自主/个别','自主/个别','自主/个别']# 大1-4班第1周上午模式(单周上午有沙水)=zhong22
da12=['建构1/个别','自主/个别','自主/个别','自主/个别','自主/个别']# 大1-4班第2周上午模式(双周上午无沙水)4次=zhong21

da21=[ '个别/建构1','个别/自主','个别/自主','个别/自主','个别/自主']# 大5-9班第1周下午模式(单周下午无沙水)=zhong12
da22=[ '个别/建构1','个别/沙水','个别/自主','个别/自主','个别/自主']# 大5-9班第2周下午模式(双周下午有沙水)4次=zhong13

zhong11=['个别/建构2','个别/沙水','个别/自主','个别/自主','个别/自主']# 中3-5班第1周下午模式(单周下午有沙水)
zhong12=['个别/建构2','个别/自主','个别/自主','个别/自主','个别/自主']# 中3-5班第2周下午模式(双周下午无沙水)3次

zhong21=['建构2/个别','自主/个别','自主/个别','自主/个别','自主/个别']# 中3-5班第1周上午模式(单周上午无沙水)3次
zhong22=['建构2/个别','沙水/个别','自主/个别','自主/个别','自主/个别']# 中3-5班第1周下午模式(单周上午有沙水)

print('-----第1周(单周)的大班前4+中班前3各的排列(有建构和沙水)----------')
# 大1-4第1周建构沙水上午班4个
list11=[]
for i in range (2):
    for k11 in da11:
        list11.append(k11)
L=[]
# 倒过来取值
for g11 in range(5,1,-1):        # 4,3,2,1,0
    lll1=list11[g11:g11+5]
    for mmm11 in lll1:
        L.append(mmm11) 
# print(L) 

# 中3-5第1周建构沙水下午班3个
list12=[]
for i in range (2):
    for k12 in zhong11:
        list12.append(k12)

for g12 in range(5,2,-1):       
    lll2=list12[g12:g12+5]
    for mmm12 in lll2:
        L.append(mmm12) 
# print(L) 

print('-----第1周(单周)的大班后4+中班后3各的排列(只有建构)----------')
# 大5-8第1周仅建构下午班4个
list13=[]
for i in range (2):
    for k13 in da21:
        list13.append(k13)
# 倒过来取值
for g13 in range(5,1,-1):        
    lll3=list13[g13:g13+5]
    for mmm13 in lll3:
        L.append(mmm13) 
# print(L) 

list14=[]
# 中6-8第1周仅建构上午班3个

for i in range (2):
    for k14 in zhong21:
        list14.append(k14)

for g14 in range(5,2,-1):       
    lll4=list14[g14:g14+5]
    for mmm14 in lll4:
        L.append(mmm14) 
# print(L) 

print('-----第2周(双周)的大班前4+中班前3各的排列(只有建构)----------')
# 大1-4第2周仅建构上午班4个
list15=[]
for i in range (2):
    for k15 in da12:
        list15.append(k15)
# 倒过来取值
for g15 in range(5,1,-1):        
    lll5=list15[g15:g15+5]
    for mmm15 in lll5:
        L.append(mmm15) 
# print(L) 

list16=[]
# 中3-5第2周仅建构下午班3个

for i in range (2):
    for k16 in zhong12:
        list16.append(k16)

for g16 in range(5,2,-1):       
    lll6=list16[g16:g16+5]
    for mmm16 in lll6:
        L.append(mmm16) 
# print(L) 

print('-----第2周(双周)的大班后4+中班后3各的排列(有建构和沙水)----------')

# 大5-8第2周建构沙水下午班4个
list17=[]
for i in range (2):
    for k17 in da22:
        list17.append(k17)

# 倒过来取值
for g17 in range(5,1,-1):        # 4,3,2,1,0
    lll7=list17[g17:g17+5]
    for mmm17 in lll7:
        L.append(mmm17) 
# print(L) 

# 中6-8第2周建构沙水上午班3个
list18=[]
for i in range (2):
    for k18 in zhong22:
        list18.append(k18)

for g18 in range(5,2,-1):       
    lll8=list18[g18:g18+5]
    for mmm18 in lll8:
        L.append(mmm18) 
print(L) 


LL=[]
# 制作足够20周的数量
for i in range(10):
    for x in L:
        LL.append(x)
print(LL)


Lwrite=[]
# print('---------第2步:如果一周有5天(不考虑跳过假日)------')
# #   
# # print('{}班'.format(gradenum[num]))
        
for i in range(int(len(LL)/5)):#第1周
    Lwrite.append(LL[5*i:5*i+5])
    # print(Lwrite)
for content in Lwrite:
    print(content)
  

print('---------第4步:xls写入)------') 
workbook = xlwt.Workbook()# 新建xls工作簿
sheet = workbook.add_sheet("Sheet")# 新建xls工作簿的工作表的名字是sheet 

# 第0列 写入班级,
classroom=[]
for l in range(0,20):
    for i in range(0,len(gradenum)):
        n="{}".format(gradenum[i])    
        classroom.append(n)          
print(classroom)        
    # print(date)

row=1
for d in range(0, len(classroom)):
    sheet.write(row, 1, classroom[d])         # 这里enumerate不能用,因为只有一列,所以就用
    row += 1    


# 第1列 写入周次(每10次一周)

dates=[]

for u in range(1,21):
    for e in range(len(gradenum)): 
            # 10个班级换一周
        n="第{}周".format('%02d'%u)    # 用遍历方法获得“第1周、第2周、第21周”字样,
        dates.append(n)          # 添加到列表    s
print(dates)        
    

row=1
for d in range(0, len(dates)):
    sheet.write(row, 0, dates[d])         # 这里enumerate不能用,因为只有一列,所以就用
    row += 1    



# 第0行 写入 星期一  '星期二','星期三','星期四','星期五  #
weeks = ['周次','班级','星期一','星期二','星期三','星期四','星期五']
week = len(weeks) 

col=0
for d in range(0, len(weeks)):
    sheet.write(0,col,weeks[d])         # 因为只有一行,所以就用有两种写法(enumerate和这种)
    col+= 1  

# 第B2开始写入 活动室内容
content = len(Lwrite)# L2['07', '08', '01', '02', '03']的长度 21组
row = 1     # 第2行
for i in range(content):         # 遍历21组[]的总数
    for col,item in enumerate(Lwrite[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\桌面\word2pdf2png\(2023.2-6)总部-班主任版-总部活动室综合安排(单周双周循环).xls")    # 新建保存 只能xls
    print('计划生成成功')
except e:
    print('失败...')
    print(e)

#

第1周效果展示(前面4个大班和前面3个中班轮到“建+沙”,后面4个大班和后面3个中班只轮到“建”)

第2周效果展示(前面4个大班和前面3个中班轮到“建”,后面4个大班和后面3个中班轮到“建+沙”)

用数据透视图“班级”分割单页(14个班级)

用替换把沙水、建构1、建构2都用不同的颜色标注,区分

重点:仔细看哦,虽然都在星期一、星期二、但是每个个字里面的上午、下午安排内容交错,不会重叠

其他表格:

用同样的方法,做了1个沙水室张贴表(显示班级)、2个建构活动室

因为只有单周、双周,所以5格的列表还是手动填入的。(如果要批量20周,用代码更有用,一两周的自己手动输入也可以。)

效果反馈:

花了2个小时写的代码,第二天发给保教主任看了。

保教主任很感慨的说:

你一个人,干翻了我们整个教研团队!

哈哈,是神奇的编程技术,完成了“纯人工”难以快速实现的结果!

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

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

相关文章

金三银四、金九银十 面试宝典 JAVASE八股文面试题 超级无敌全的面试题汇总(接近3万字的面试题,让你的JAVA语法基础无可挑剔)

JavaSE八股文 - 面试宝典 一个合格的 计算机打工人 ,收藏夹里必须有一份 JAVA八股文面试题 ,特别是即将找工作的计算机人,希望本篇博客对你有帮助! 本文参考了诸多大佬的面试题帖子,ps:白大锅、哪吒、英雄…

从Linux内核中学习高级C语言宏技巧

Linux内核可谓是集C语言大成者,从中我们可以学到非常多的技巧,本文来学习一下宏技巧,文章有点长,但耐心看完后C语言level直接飙升。 本文出自:大叔的嵌入式小站,一个简单的嵌入式/单片机学习、交流小站 从…

机器看世界

博主简介 博主是一名大二学生,主攻人工智能研究。感谢让我们在CSDN相遇,博主致力于在这里分享关于人工智能,c,Python,爬虫等方面知识的分享。 如果有需要的小伙伴可以关注博主,博主会继续更新的&#xff0c…

为什么红黑树如此受欢迎

平衡二叉查找树有很多,但是我们一提到平衡二叉查找树,常提及的就是红黑树,它的“出镜率”甚至要高于平衡二叉查找树。 红黑树是一种相对平衡的二叉查找树,不符合严格意义上平衡二叉查找树的定义。 目录 红黑树的插入 红黑树的验…

SAP ABAP WebService

第一步:SE37 创建一个远程函数(Remote Function Module)注意该函数需要将Remote Enable开启第二步:创建WebService首先:SE37 打开需要关联的函数在菜单 Utilities->More Utilities->Create Web Service->From…

二 Go的基本语法

1. 基本类型 boolstringint、int8、int16、int32、int64uint、uint8、uint16、uint32、uint64、uintptrbyte // uint8 的别名rune // int32 的别名 代表一个 Unicode 码float32、float64complex64、complex128 2. 三种声明变量 2.1 标准格式 var name type 其中,…

MyBatis-Plus联表查询的短板,该如何解决呢

mybatis-plus作为mybatis的增强工具,它的出现极大的简化了开发中的数据库操作,但是长久以来,它的联表查询能力一直被大家所诟病。一旦遇到left join或right join的左右连接,你还是得老老实实的打开xml文件,手写上一大段…

链表及其基本操作

1.单链表:1.1定义/性质:链表是线性表的链式存储方式。单链表通过指针线性遍历,删除/增加节点时间复杂度为O(1),访问节点时间复杂度为O(n)。单链表分为带头结点和不带头结点两种,带头结点是为了方便统一操作&#xff08…

数据结构:链式二叉树初阶

目录 一.链式二叉树的逻辑结构 1.链式二叉树的结点结构体定义 2.链式二叉树逻辑结构 二.链式二叉树的遍历算法 1.前序遍历 2.中序遍历 3.后序遍历 4.层序遍历(二叉树非递归遍历算法) 层序遍历概念: 层序遍历算法实现思路: 层序遍历代码实现: 三.链式二叉树遍历算…

蓝桥杯三月刷题 第六天

文章目录💥前言😉解题报告💥星期计算🤔一、思路:😎二、代码:💥考勤刷卡🤔一、思路:😎二、代码:💥卡片🤔一、思路:😎二、代…

Spring SpringBoot中使用Mybatis-plusDemo1

官网:https://baomidou.com GitHub:GitHub - baomidou/mybatis-plus: An powerful enhanced toolkit of MyBatis for simplify development Gitee:mybatis-plus: mybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com低代码组件库 http://aizuda.com My…

Leetcode.剑指 Offer II 023. 两个链表的第一个重合节点

题目链接 Leetcode.剑指 Offer II 023. 两个链表的第一个重合节点 easy 题目描述 给定两个单链表的头节点 headA和 headB,请找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null。 注意,函数返回结果后,链表必…

Lumion 2023即将上线,低配电脑如何驾驭Lumion

年更选手Lumion的更新速度“从不让人失望”,自从Lumion 12更新完之后,官方意料之中的没了动静。但是就在这几天,官方终于放出了首支Lumion 2023的更新预告,并且宣布将于本月中旬发布!Lumion 2023主要变化是支持光线追踪…

【Linux:环境变量的理解】

目录 1 Z(zombie)-僵尸进程 2 孤儿进程 3 环境变量 3.1 基本概念 3.2 测试HOME 3.3 和环境变量相关的命令 3.4 环境变量的组织方式 3.5 环境变量通常是具有全局属性的 在讲环境变量之前,我们先把上次遗留知识点给总结了(僵尸进程和孤儿进程&…

fast-api 一款快速将spring的bean发布成接口并生产对应swagger文档调试的轻量级工具

fast-api简介背景开发痛点:分析需求实战fast-api快速上手1. 引入依赖2. FastApiMapping标记service对象3. swagger2/knife4j 在线测试进阶使用开启调试模式支持指定类或包目录发布如何关闭fast-api自定义fast-api的前缀写在最后简介 fast-api 一款快速将spring的bean(service)发…

案例学习6-没有复用思想

背景: 上述两个方法查询同一张表,只是数据结构不同,完全可以合成一份方法,减少代码冗余。 实现效果如下 不传参,查询所有的数据 传入特定参数实现按条件查询: 实现方式: GetMapping(value &q…

Antlr Tool与antlr runtime的版本一致性问题

1. 意外的问题 在学习Antlr4的visitor模式时,使用IDEA的Antlr插件完成了Hello.g4文件的编译,指定的package为com.sunrise.hello 使用visitor模式遍历语法解析树,遍历过程中打印hello语句 public class HelloVisitorImpl extends HelloBaseVi…

Linux进程和任务管理和分析和排查系统故障

♥️作者:小刘在C站 ♥️个人主页:小刘主页 ♥️每天分享云计算网络运维课堂笔记,努力不一定有收获,但一定会有收获加油!一起努力,共赴美好人生! ♥️夕阳下,是最美的绽放&#xff0…

基于遥感解译与GIS技术生态环境影响评价图件制作

《环境影响评价技术导则 生态影响》(HJ 19—2022)即将实施,其中生态影响评价图件是生态影响评价报告的必要组成内容,是评价的主要依据和成果的重要表现形式,是指导生态保护措施设计的重要依据。在众多图件中&#xff…

java八股文--java基础

java基础1.什么是面向对象,谈谈对面向对象的理解2.JDK JRE JVM的区别与联系3.和equals4.hashCode与equals5.String StringBuffer StringBuilder的区别6.重载和重写的区别7.接口和抽象类8.List和Set的区别9.ArrayList和LinkedList10.HashMap和HashTable的区别&#x…