作品展示:
背景需求:
上一篇批量制作了“7天轮回14班沙水+每周固定建构”的活动室内排班表。
一、时段冲突,调整单双周。
保教主任抽空检查后,提到:“一个班、上午、下午都有自主游戏(沙水、建构、表演、角色)是不对的,通常每天上午一个自主游戏、下午就必须是个别化学习。同理上午是个别化学习,下午就是自主游戏
按原有排序方式,7天轮流沙水与5天建构游戏永远有出现3次重合。不符合排序规律。
我们讨论后,保教主任同意14个班级”2周轮一次沙水(1个沙水活动室),1周轮一次建构(2个建构活动室)“
结论:时间宽裕了,理论上排序更便利。
二、时段信息,详细标注
但是她又提出新的需求。
时段罗列:各班一周5天表格内需要写成”沙水/个别”“建构/个别”“自主/个别”的形式,前者代表上午场活动,后者代表下午场活动。
场所写明:涉及到两个建构活动室,最好表明“大班-建构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个小时写的代码,第二天发给保教主任看了。
保教主任很感慨的说: