背景需求
上学期的周安排里,每班每周的自主游戏会轮到多个不同的内容
因此在每周的自主游戏观察有2次记录,观察的项目可以写不一样的,
如一位老师写沙水游戏,另一位写表演游戏
本学期,中班的自主游戏全部是户外的,并且每班每周5天玩同一个内容。
因此《自主游戏观察记录表》的记录内容就会改变------
1、每周2篇记录都是同一个项目(如都是观察"建构")
2、必须是户外游戏的内容(以前都是室内观察的内容)
为了更好的便于班主任进行游戏观察记录,我想预先就制作一个包含本班轮到的项目和场地的提示说明。
参考资料
素材准备:
一、原始模板示例及需要修改的红色部分
1、删除其中的观察文字部分
2、需要替换的包括:周次、年级、班级号、教师1、教师2、
3、主要补充内容:在游戏观察部分增加"((游戏名称)(游戏场地))",1周内的两次游戏观察内容是一样的
二、自主游戏观察记录模板
1、把相关内容改成{{XXX}}的样式
2、标题2行,所以导致表格延伸到第2页,这个需要反复测试,调整框架,确保每周的格子都在一页上。
三、EXCEL的内容
代码展示:
python
# -*- coding:utf-8 -*- 1
'''
自主游戏观察记录模板-只有中四班
作者:阿夏
时间:2024年2月23日
'''
# 一、导入相关模块,设定excel所在文件夹和生成word保存的文件夹
from docxtpl import DocxTemplate
import pandas as pd
import os
import time
#
print('----------第1步:制作路径----')
zpath=os.getcwd()+'\\'
zpath=r'C:\Users\jg2yXRZ\OneDrive\桌面\周计划\01自主游戏观察记录模板制作'+'\\'
file_path=zpath+'零时\\'
# print(file_path)
# r'\零时Word'
print('----------第2步:遍历excel,逐个生成word(form.docx是前面的模板)------------')
try:
os.mkdir(file_path)
except:
pass
# tpl = DocxTemplate(zpath+'自主游戏观察记录模板.docx')
IDcard = pd.read_excel(zpath+'数据.xlsx')
week=IDcard["week"]
grade = IDcard["grade"]
number=IDcard["number"]
# str.rstrip()
T1=IDcard["T1"] # str.rstrip()用于去掉换行符
T2=IDcard["T2"] # str.rstrip()用于去掉换行符
content=IDcard["content"] # str.rstrip()用于去掉换行符
# math = autho['math']
# eng = autho['eng']
# 遍历excel行,逐个生成
num = IDcard.shape[0]
for i in range(num):
context = {
"week": week[i],
"grade": grade[i],
"number": number[i],
"T1": T1[i],
"T2": T2[i],
"content": content[i],
}
tpl = DocxTemplate(zpath+'自主游戏观察记录模板.docx')
tpl.render(context)
# tpl.save(file_path+r"\{} 的身份证.docx".format(name[i]))
#
tpl.save(file_path+"合并{}.docx".format('%02d'%week[i]))
print('----------第3步:doc 文档合并------------')
# 合并所有Word
import win32com.client as win32
import os
word = win32.gencache.EnsureDispatch('Word.Application')
#启动word对象应用
word.Visible = False
files = []
for filename in os.listdir(file_path):
filename = os.path.join(file_path,filename)
files.append(filename)
#新建合并后的文档(使用模板,进行12个文件夹的合并,把12个文件夹的内容贴到已有的模板(包含0.7边、四分栏))
output = word.Documents.Add()
for file in files:
output.Application.Selection.InsertFile(file)#拼接文档
#获取合并后文档的内容
doc = output.Range(output.Content.Start, output.Content.End)
# 合并word
lspathall=zpath+'{}({})班自主游戏观察记录(202402-202406).docx'.format(grade[i],number[i])
output.SaveAs(lspathall) #保存
output.Close()
print('----------第4步:删除临时文件夹------------')
import shutil
shutil.rmtree(file_path) #递归删除文件夹,即:删除非空文件夹