【办公类-16-10-01】“2023下学期 中4班 自主游戏观察记录(python 排班表系列)

背景需求

上学期的周安排里,每班每周的自主游戏会轮到多个不同的内容

因此在每周的自主游戏观察有2次记录,观察的项目可以写不一样的,

如一位老师写沙水游戏,另一位写表演游戏

本学期,中班的自主游戏全部是户外的,并且每班每周5天玩同一个内容。

因此《自主游戏观察记录表》的记录内容就会改变------

1、每周2篇记录都是同一个项目(如都是观察"建构")

2、必须是户外游戏的内容(以前都是室内观察的内容)

为了更好的便于班主任进行游戏观察记录,我想预先就制作一个包含本班轮到的项目和场地的提示说明。

参考资料

【办公类-19-03】办公中的思考------Python批量制作word单元格照片和文字(小照片系列)-CSDN博客文章浏览阅读826次。【办公类-19-03】办公中的思考------Python批量制作word单元格照片和文字(小照片系列)https://blog.csdn.net/reasonsummer/article/details/132747236

素材准备:

一、原始模板示例及需要修改的红色部分

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) #递归删除文件夹,即:删除非空文件夹

终端显示(主要步骤)

生成结果:

用这样的方法,可以快速生成一份本学期本班专用的《自主游戏观察记录表》。

相关推荐
susu10830189112 分钟前
python实现根据搜索关键词爬取某宝商品信息
爬虫·python
喜欢猪猪28 分钟前
Java技术专家视角解读:SQL优化与批处理在大数据处理中的应用及原理
android·python·adb
海绵波波10730 分钟前
flask后端开发(1):第一个Flask项目
后端·python·flask
林的快手35 分钟前
209.长度最小的子数组
java·数据结构·数据库·python·算法·leetcode
从以前1 小时前
准备考试:解决大学入学考试问题
数据结构·python·算法
Ven%1 小时前
如何修改pip全局缓存位置和全局安装包存放路径
人工智能·python·深度学习·缓存·自然语言处理·pip
枫欢1 小时前
将现有环境192.168.1.100中的svn迁移至新服务器192.168.1.4;
服务器·python·svn
测试杂货铺2 小时前
UI自动化测试实战实例
自动化测试·软件测试·python·selenium·测试工具·测试用例·pytest
余~~185381628002 小时前
NFC 碰一碰发视频源码搭建技术详解,支持OEM
开发语言·人工智能·python·音视频
苏三有春2 小时前
PyQt实战——使用python提取JSON数据(十)
python·json·pyqt