【教学类-23-02】20240929《不会写学号的中班幼儿的学号描字贴》(中2班描字)

news2024/9/30 3:27:09

背景需求:

今天给孩子们做中班操作材料包《练眼力》,希望他们在操作纸左上角写学号,结果有不少孩子嚷:“我不会写学号!”

“不会写的孩子举手,老师给你们做个字帖”

结果有不少孩子都举手了,我把学号抄下来。

有12人,如果算上没有来园的2人,14/29占总数48.27%,毕竟是中班上学期,不会写学号也正常。

但是为了区分物权,哪怕是“画数字”也希望他们在作业上留下记号。

我用了以前写的代码,复制一份

【教学类-23-01】20221217《不会写学号的中班幼儿的学号描字贴》(中班描字)_幼儿学号用word制作-CSDN博客文章浏览阅读659次。【教学类-23-01】20221217《不会写学号的中班幼儿的学号描字贴》(中班描字)_幼儿学号用word制作https://blog.csdn.net/reasonsummer/article/details/128357121

只修改了字体“杨任东竹石体—Regular”,

因为字体变化,复制word模板,并修改模版里的段落间距、调整了字体的字号。确保它撑满格子。

代码展示


'''
作者:阿夏
时间:2024年9月28日
名称:中2班不会写名字的孩子练习学号12人
'''

import xlwt
import xlrd
import os
import random
from win32com.client import constants,gencache
from win32com.client.gencache import EnsureDispatch
from win32com.client import constants # 导入枚举常数模块

import os,time
import docx
from docx import Document
from docx.shared import Pt 
from docx.shared import RGBColor
from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
from docx.oxml.ns import qn

from docxtpl import DocxTemplate
import pandas as pd
from docx2pdf import convert
from docx.shared import RGBColor

path=r"C:\Users\jg2yXRZ\OneDrive\桌面\描字帖"


wb= xlrd.open_workbook(path+r"\学生名单.xlsx") #打开文件并返回一个工作蒲对象。open_workbook可以点进去看看函数里面的参数的含义之类的,很详细,英语不好的可以百度翻译,翻译出来的结果差不多。
sheet=wb.sheet_by_index(0)   #通过索引的方式获取到某一个sheet,现在是获取的第一个sheet页,也可以通过sheet的名称进行获取,sheet_by_name('sheet名称')
col1=sheet.col_values(0)# 学号
col2=sheet.col_values(1)# 名字
num=len(col1)-1  # 第一列去掉第一行

# 幼儿学号
num1=[8,9,10,12,15,20,21,23,26,27,28,29]

l=[]
# 生成 基本组:“学号“
for i in range(1,len(col1)):
    # for d in range(8):
    name='{}'.format (int(col1[i]) )    #学号
    l.append(name)    
print(l)# 32个名字

# 单元格坐标 
# zb=['35','46','55','68','44','79']
zb=['34','45','54','67','43','78']

# 6个表格所有的table[bg] 
bg=[]

for i in range(0,len(zb)):
    # print(i)
    for x in range(0,int(zb[i][1])):        # 行
        for y in range(0,int(zb[i][0])):            #列
            bg.append('{}{}'.format(x,y)) 
# print(len(bg)) 
# # 162
# print(bg) 
# ['00', '01', '02', '10', '11', '12', '20', '21', '22', '30', '31', '32', '00', '01', '02', '03', '10', '11', '12', '13', '20', '21', '22', '23', '30', '31', '32', '33', '40', '41', '42', '43', '00', '01', '02', '03', '04', '10', '11', '12', '13', '14', '20', '21', '22', '23', '24', '30', '31', '32', '33', '34', '00', '01', '02', '03', '04', '05', '10', '11', '12', '13', '14', '15', '20', '21', '22', '23', '24', '25', '30', '31', '32', '33', '34', '35', '40', '41', '42', '43', '44', '45', '50', '51', '52', '53', '54', '55', '60', '61', '62', '63', '64', '65', '00', '01', '02', '03', '10', '11', '12', '13', '20', '21', '22', '23', '00', '01', '02', '03', '04', '05', '06', '10', '11', '12', '13', '14', '15', '16', '20', '21', '22', '23', '24', '25', '26', '30', '31', '32', '33', '34', '35', '36', '40', '41', '42', '43', '44', '45', '46', '50', '51', '52', '53', '54', '55', '56', '60', '61', '62', '63', '64', '65', '66', '70', '71', '72', '73', '74', '75', '76']

# 把zb做成索引数量
# 第一次,X*Y=Z
# zb=['34','45','54','67','43','78']
zb1=[]
zb1.append(0)
for t in range(len(zb)):
    b=int(zb[t][0])*int(zb[t][1])
    zb1.append(b)
print(zb1)
# zb1=[0, 12, 20, 20, 42, 12, 56]

# 第二次:反复相加
zb2=[]
# zb1= [0, 12, 20, 20, 42, 12, 56]
for m in range(1,len(zb1)+1):
    zb2.append(sum(zb1[:m]))
print(zb2)
# zb2=[0, 12, 32, 52, 94, 106, 162]

#  第三次,提取两个索引数字
bg_all=[]

xx = zb2[0:len(zb2)-1]# [0, 12, 32, 52, 94, 106] 
yy = zb2[1:len(zb2)] # [12, 32, 52, 94, 106, 162]
zz= dict(zip(xx,yy))
# print(bg_all)
# zz={0: 12, 12: 32, 32: 52, 52: 94, 94: 106, 106: 162}

# 6套坐标索引分割开来
for k,v in zz.items():    # 提取键key(第一个)值value(第二个)
    print(k,v)
    g=bg[int(k):int(v)]
    # print(g)
    bg_all.append(g)
print(bg_all)
# [['00', '01', '02', '10', '11', '12', '20', '21', '22', '30', '31', '32'], ['00', '01', '02', '03', '10', '11', '12', '13', '20', '21', '22', '23', '30', '31', '32', '33', '40', '41', '42', '43'], ['00', '01', '02', '03', '04', '10', '11', '12', '13', '14', '20', '21', '22', '23', '24', '30', '31', '32', '33', '34'], ['00', '01', '02', '03', '04', '05', '10', '11', '12', '13', '14', '15', '20', '21', '22', '23', '24', '25', '30', '31', '32', '33', '34', '35', '40', '41', '42', '43', '44', '45', '50', '51', '52', '53', '54', '55', '60', '61', '62', '63', '64', '65'], ['00', '01', '02', '03', '10', '11', '12', '13', '20', '21', '22', '23'], ['00', '01', '02', '03', '04', '05', '06', '10', '11', '12', '13', '14', '15', '16', '20', '21', '22', '23', 
# '24', '25', '26', '30', '31', '32', '33', '34', '35', '36', '40', '41', '42', '43', '44', '45', '46', '50', '51', '52', '53', '54', '55', '56', '60', '61', '62', '63', '64', '65', '66', '70', '71', '72', '73', '74', '75', '76']]

size=[118,84,66,53,85,44]

# # # font=['楷体','楷体','楷体','隶书','华文新魏','华文彩云','方正姚体','幼圆']# 8种字体

print('----------第1步:新建一个临时文件夹------------')
# 新建一个”装N份word和PDF“的文件夹
tencent=path+r'\零时Word'
os.makedirs(tencent,exist_ok=True)
# doc= docx.Document(r"C:\Users\jg2yXRZ\OneDrive\桌面\描字贴\打印合集描字贴.docx")# 新建Word

for n in range(0,num):    # 一共多少份
    doc = docx.Document(path+r"\中2班不会写学号的孩子的描字帖练习册.docx")
    for t in range(0,len(bg_all)):
        table = doc.tables[t]   
        for p in range(0,int(len(bg_all[t]))):
                   # 一共有9个表格

            
            pp=int(bg_all[t][p][0])     # 提取表格bg里面每个元素的第0个数字==单元格X坐标  t=索引数字
            qq=int(bg_all[t][p][1]) 
            # f=font[t]        # 字体格式
            k=l[n]               # 从4名字里提取名字\
            ss=size[t]
            print(pp,qq,k)

            run=table.cell(pp,qq).paragraphs[0].add_run(k)    # 在单元格0,0(第1行第1列)输入第0个名字
            run.font.name = '杨任东竹石体-Regular'  #输入时不同字体
            run.font.size = Pt(ss)  #输入字体大小80或68号
            run.font.color.rgb = RGBColor(200,200,200) #设置颜色10%黑色=深灰
        
            r = run._element
            r.rPr.rFonts.set(qn('w:eastAsia'), '杨任东竹石体-Regular' )#将输入语句中的中文部分字体变为华文行楷
            table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中

    doc.save(tencent+fr'\{n:02}.docx')#保存为XX学号的零时word

    from docx2pdf import convert
    # docx 文件另存为PDF文件
    inputFile = tencent+fr'\{n:02}.docx'# 要转换的文件:已存在
    outputFile = tencent+fr'\{n:02}.pdf' # 要生成的文件:不存在
    # 先创建 不存在的 文件
    f1 = open(outputFile,'w')
    f1.close()
    # 再转换往PDF中写入内容
    convert(inputFile, outputFile)

    from docx2pdf import convert

print('----------第4步:把都有PDF合并为一个打印用PDF------------')

import os
from PyPDF2 import PdfFileMerger
target_path = tencent
pdf_lst = [f for f in os.listdir(target_path) if f.endswith('.pdf')]
pdf_lst = [os.path.join(target_path, filename) for filename in pdf_lst]
pdf_lst.sort()
file_merger = PdfFileMerger()
for pdf in pdf_lst:
    print(pdf)
    file_merger.append(pdf)
# file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/描字帖/(打印合集)大班A整页描字帖2乘5加表格-4名字-({}人).pdf".format(num))
file_merger.write(path+fr"\20240928中2班不会写学号的孩子的描字帖练习册({num}份).pdf")
file_merger.close()
# doc.Close()

# # print('----------第5步:删除临时文件夹------------')    
import shutil
shutil.rmtree(tencent) #递归删除文件夹,即:删除非空文件夹`

生成结果

打印

切开

左侧装订

本次记号笔和彩色水笔会渗透到下一页,所以垫了一张铅画纸

该幼儿一直有镜像视觉(把21写成12)在自主书写,发现幼儿写的数字都是左右镜像,而且出现旋转,每次写的数字的角度都不一样。

左侧孩子家里没有练过,无法正确捏笔

我的搭班老师指导幼儿正确捏笔

不会写,哭了,同意停止。

我画了一个起始点,幼儿能够照着样子画了8,书写姿势正确。但线条虚浮,手指肌群灵活性、力度不足但是后面空白写数字8,还是两个分开的0,

幼儿能够正确姿势描红,自主书写时,可以写出2,无法写3

写的很好,也能自己写20(昨天举手纯属跟风)

利用早晨来园半小时写的,还有部分孩子没有来。

后续再练习看看,希望孩子们都能“画出学号”,便于确认物权

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

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

相关文章

opencv学习:Harris角点检测和SIFT(尺度不变特征变换)算法完整代码实现

Harris角点检测 概念 Harris角点检测是一种在图像处理和计算机视觉领域广泛使用的技术,用于检测图像中的角点。角点是图像中两条边缘交点的位置,它们在图像分析、目标识别和图像配准等任务中非常重要。 角点:图像中的角点是指图像局部区域…

GDB :代码调试工具

文章目录 一、启动GDB二、GDB的基本命令1. 显示代码2. 运行程序3. 设置断点4. 单步执行5. 查看变量和内存6. 查看函数调用堆栈7. 修改变量值8. 退出GDB 一、启动GDB 在终端中,使用以下命令启动GDB并加载你的可执行文件: gdb ./your_program会进入以下界…

应用性能管理工具-SkyWalking

前言 随着微服务架构的流行,一次请求往往需要涉及到多个服务,因此服务性能监控和排查就变得更复杂,因此,就需要一些可以帮助理解系统行为、用于分析性能问题的工具,以便发生故障的时候,能够快速定位和解决…

关于大模型的10个思考

9月28日,第四届“青年科学家50论坛”在南方科技大学举行,美国国家工程院外籍院士沈向洋做了《通用人工智能时代,我们应该怎样思考大模型》的主题演讲,并给出了他对大模型的10个思考。 以下是他10个思考的具体内容: 1…

STM32移植RT-Thread实现DAC功能

在进行DAC的学习中,发现RT-Thread中没有该外设的驱动,因此需要自己进行相关配置 1.配置RT-Thread Setting中的DAC组件 2.在HAL库中完成DAC的配置(HAL库起到时钟的作用) 不懂HAL库配置的最好学一下HAL库的编程思想 3.在board.h中添加宏定义 我的RT-T…

关于分箱的一些介绍

在这篇文章中,我将介绍一种数据预处理的技术——分箱,然会将会从概念、步骤、分类、应用场景、注意事项与实际操作等方面去介绍它。 一、概念 分箱(Binning)是一种数据预处理技术,在数据分析和机器学习中经常使用。它…

Java8 用流收集数据之归约汇总

目录 规约汇总最大值 (max)・最小值 (min)统计总数 (count)统计求和 (summingInt・summingLong・summingDouble・sum)平均值 (averagingInt・averagingLong・averagingInt・average)统计梗概 (summarizingInt・summarizingLong・summarizingDouble・summ…

AI周报(9.22-9.28)

AI应用-Siipet宠物沟通师 Siipet是一款由SiiPet公司推出的创新宠物行为分析相机,旨在通过尖端技术加深宠物与主人之间的情感联系。这款相机利用先进的AI算法,能够自动识别和分析家中宠物的行为,并提供定制化的护理建议。 SiiPet相机的核心功…

益而益集团荣获2024年江苏省智能制造车间称号

近日,江苏省工信厅公示2024年江苏省智能制造车间名单,苏州益而益电器制造有限公司以其卓越的智能化转型成果,荣获2024年度江苏省级智能制造车间称号。 此次获评,是江苏省政府对益而益集团智能化高质量转型发展的认可及肯定&#…

活动在线报名小程序源码系统 自主提交表单+创建表单 带完整的安装代码包以及搭建部署教程

系统概述 随着各类活动的日益丰富和多样化,传统的报名方式逐渐显现出其局限性。纸质报名表格繁琐易错、人工统计费时费力,难以满足现代活动管理的需求。因此,开发一款集自主提交表单和创建表单功能于一体的活动在线报名小程序源码系统成为必…

mit6824-01-MapReduce详解

文章目录 MapReduce简述编程模型执行流程执行流程排序保证Combiner函数Master数据结构 容错性Worker故障Master故障 性能提升定制分区函数局部性执行缓慢的worker(slow workers) 常见问题总结回顾参考链接 MapReduce简述 MapReduce是一个在多台机器上并行计算大规模数据的软件架…

C++进阶知识2 多态

多态 1. 多态的概念2. 多态的定义及实现2.1 多态的构成条件2.1.2 虚函数2.1.3 虚函数的重写/覆盖2.1.5 虚函数重写的⼀些其他问题2.1.6 override和final关键字2.1.7 重载/重写/隐藏的对⽐ 3. 多态的原理3.2 多态的原理3.2.1 多态是如何实现的3.2.2 动态绑定与静态绑定3.2.3 虚函…

828华为云征文|部署在线文档应用程序 CodeX Docs

828华为云征文|部署在线文档应用程序 CodeX Docs 一、Flexus云服务器X实例介绍二、Flexus云服务器X实例配置2.1 重置密码2.2 服务器连接2.3 安全组配置2.4 Docker 环境搭建 三、Flexus云服务器X实例部署 CodeX Docs3.1 CodeX Docs 介绍3.2 CodeX Docs 部署3.3 CodeX…

SpringBoot整合JPA 基础使用

一、什么是JPA ‌‌1.JPA的定义和基本概念‌‌ ‌JPA(Java Persistence API)‌是Java中用于进行持久化操作的一种规范,它定义了一系列用于操作关系型数据库的API接口。通过这些接口,开发人员可以方便地进行数据库的增删改查等操…

ArcgisEngine开发中,Ifeatureclass.Addfield 报错0x80040655处理方法

1、ArcgisEngine开发中,Ifeatureclass.Addfield 报错0x80040655。如下图所示。 2、经分析,这是由于字段类型错误,经检查,是由于字段名为中文名,超出shp格式的最大字段长度量,看资料说是5个中文字符&#xf…

fastadmin 搜索提交重置按钮文本修改

默认 修改require-backend.min.js文件 效果 当然最好还是去需修改lang文件 效果 如果修改没生效记得清楚一下缓存,再刷新 完结 赠人玫瑰,手有余香!如果文章内容对你有所帮助,请不要吝啬你的点赞评论和关注,你…

校园跑腿系统二手市场校园搭子校园社团活动系统2000的和4800的有什么区别

校园跑腿系统、二手市场、校园搭子、校园社团活动系统在不同价格档位(如2000元和4800元)之间可能存在多方面的区别,这些区别主要体现在功能丰富性、技术支持、用户体验、定制化程度以及后续服务等方面。然而,由于具体的价格差异和…

TDengine 流计算与窗口机制的深度解析:揭示计数窗口的关键作用

在 TDengine 3.2.3.0 版本中,我们针对流式计算新增了计数窗口,进一步优化了流式数据处理的能力。本文将为大家解读流式计算与几大窗口的关系,并针对新增的计数窗口进行详细的介绍,帮助大家进一步了解 TDengine 流式计算&#xff0…

趣味SQL | 从围棋收官到秦楚大战的数据库SQL实现(下)

目录 0 上集回顾 1 双先量化,得失权衡 2 各守城池,妥协攻守 3 SQL演算,三策评详 4 寸土必争,利益倍增 5 SQL再演,策略精进 6 棋道相通,治国有术 如果觉得本文对你有帮助,那么不妨也可…

这是我见过最强的AI大模型教程书籍!免费白嫖,可以上车!!

这是LLM入门级书籍,共145页,主要介绍了大型语言模型(LLM)的基本原理和底层技术。 阅读本书,您将能够掌握 LLM 的基本概念,了解自然语言处理(NLP)的发展历程,理解 Transf…