【教学类-34-04】20230422拼图(汉字姓氏-正方块拼图)2*2格子(中班主题《个别化拼图》偏语言)

本文主要是介绍【教学类-34-04】20230422拼图(汉字姓氏-正方块拼图)2*2格子(中班主题《个别化拼图》偏语言),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作品展示 

素材准备:

 

代码展示:

'''
项目:名字姓氏矢量图的3*3格拼图  1页两份 横版
作者:阿夏
日期:2023年4月20日21:47
'''num=int(input('生成多少人(28人)\n'))
# num=int(input('生成多少份(4 ABCD四个字母)\n'))Number=int(input('随机抽取几个图片(4个)\n'))print('----------第1步:19张大写字母PNG图片*每张图片切割12张----------------')
# 源代码: https://blog.csdn.net/qq_34777982/article/details/125019068?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_baidulandingword~default-1-125019068-blog-129622294.235^v29^pc_relevant_default_base3&spm=1001.2101.3001.4242.2&utm_relevant_index=4
# Python 裁剪九宫格图片 —— 筑梦之路
import sys
import os 
from PIL import Image# # 生成名字  暂时手写
name=['01赵','02钱','03孙','04李']# # 读取EXCEL文件的名单
# import openpyxl
# import xlrd
# import pandas as pd# worksheet = xlrd.open_workbook(r'C:\Users\jg2yXRZ\OneDrive\桌面\汉字姓氏拼图\中6班点名单.xlsx')
# sheet_names= worksheet.sheet_names()
# print(sheet_names)# for sheet_name in sheet_names:
#     sheet = worksheet.sheet_by_name(sheet_name)
#     rows = sheet.nrows # 获取行数
#     cols = sheet.ncols # 获取列数,尽管没用到
#     all_content = []
#     cols = sheet.col_values(1) # 获取第二列内容, 数据格式为此数据的原有格式(原:字符串,读取:字符串;  原:浮点数, 读取:浮点数)#     # print(cols)
#     name=cols[1:]
#     print(name)
#     # print(type(cols[1]))    #查看数据类型# name_list = ["张三", "李四", "周瑜", "张三", "张三", "李四", "王五", "张飞", "张飞", "周瑜"]# 把文字转成图片
#载入必要的模块
import pygame
#pygame初始化
pygame.init()
for w in range(len(name)):
# 待转换文字text = u"{}".format(name[w][0])#设置字体和字号# font = pygame.font.SysFont('Arial Black', 2000)  font = pygame.font.SysFont('华文仿宋 ', 1000)     # 华文系列可以用# 华文彩云# 华文仿宋  # 华文琥珀# 华文楷体# 华文隶书# 华文宋体# 华文细黑# 华文新魏# 华文行楷# 华文中宋# 汉字能够生成的只要华文彩云#渲染图片,设置背景颜色和字体样式,前面的颜色是字体颜色# ftext = font.render(text, True,(220, 220, 220),(255, 255, 255))ftext = font.render(text, True,(150, 150, 150),(255, 255, 255))#保存图片pygame.image.save(ftext, r"C:\Users\jg2yXRZ\OneDrive\桌面\汉字姓氏拼图\汉字姓氏拼图0\{}.jpg".format('%02d'%(w+1)))#图片保存地址# 生成0里面的图片大小# 1146     # 687 # 批量调整图片的大小
# 生成0里面的图片大小# 1146     # 687  改成600*400
from PIL import Image
import os# 原始文件夹路径
original_folder = "C:/Users/jg2yXRZ/OneDrive/桌面/汉字姓氏拼图/汉字姓氏拼图0"
# 保存的新文件夹路径
new_folder = "C:/Users/jg2yXRZ/OneDrive/桌面/汉字姓氏拼图/汉字姓氏拼图"# 遍历原始文件夹中的图像
for filename in os.listdir(original_folder):img = Image.open(os.path.join(original_folder, filename))# 改变尺寸img_resized = img.resize((600, 600))   #这里是你要转换的尺寸 两个数字能被3整除# 保存到新文件夹img_resized.save(os.path.join(new_folder, filename))file_root = r"C:\Users\jg2yXRZ\OneDrive\桌面\汉字姓氏拼图\汉字姓氏拼图" #要切的图片放的文件
fileList = []
n = 0
#读取文件列表
def read_bmp_file_list(path):for root, dirs, files in os.walk(path, topdown=False):for file in files:fileList.append(os.path.join(root, file))
#开始切图 9格
def qie_tu(file_path):global nim = Image.open(file_path)# 图片的宽度和高度(原始图片大小1280 720)img_size = im.sizeprint("小图片宽度和高度分别是{}".format(img_size))#切成512X512x = 0y = 0w = 300   # 列几条?600/3h = 300   # 行几条?400/3for j in range(0,2):for i in range(0,2):#region = im.crop((x, y, x+w*i, y+h*j))print(x+w*i, y+h*j,x+w*i+w, y+h*j+h)region = im.crop((x+w*i, y+h*j,x+w*i+w, y+h*j+h))#文件输出位置region.save(r"C:\Users\jg2yXRZ\OneDrive\桌面\汉字姓氏拼图\汉字姓氏拼图1\{name}.jpg".format(name='%03d'%n))n=n+1if __name__ == '__main__':read_bmp_file_list(file_root)for f in fileList:qie_tu(f)# print('----------第2步:读取图片,写入模板----------------')
import os
from PIL import Image print('----------第1步:提取图片路径------------')path=[]
pr="C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\汉字姓氏拼图\\汉字姓氏拼图1"
# 过滤:只保留png结尾的图片
imgs1=os.listdir(pr)
for img1 in imgs1:if img1.endswith(".jpg"):path.append(pr+'\\'+img1)
# 所有图片的路径
print(path)
# 216条路径(18张*12图)
print(imgs1)print('----------第2步:新建一个临时文件夹------------')
# 新建一个”装N份word和PDF“的文件夹
os.mkdir(r'C:\Users\jg2yXRZ\OneDrive\桌面\汉字姓氏拼图\零时Word')print('----------第3步:随机抽取9张图片 ------------')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
import randomimport os,time
import docx
from docx import Document
from docx.shared import Inches,Cm,Pt
from docx.shared import RGBColor
from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
from docx.oxml.ns import qnfrom docxtpl import DocxTemplate
import pandas as pd
from docx2pdf import convert
from docx.shared import RGBColorfor nn in range(0,int(num/2)):    #28/2 0-14doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\汉字姓氏拼图\汉字姓氏拼图模板.docx')
#     # 制作列表    # 从左边图列表和右边图列表中抽取图片(12张图片,可能5个向左、7个向右边)# 24条里面0和12条是一组,2个里面随机抽1一个,1和13是一组,2个里面随机抽一个…… 抽出12个图片后r=[]    c=[]r.append(path[nn*8:nn*8+8])        # 左侧第一份,# r.append(path[nn*24:nn*24+24])        # 连续12张图片、2份字母插入同一份A4# print(r)# 再打乱顺序读取12个      for a in r:for b in a:c.append(b)print(c)    figures1=random.sample(c[0:4],Number)    # 前9张不重复打乱     figures2=random.sample(c[4:8],Number)    # 后9张不重复打乱# figures3=random.sample(c[12:18],Number)    # 后6张不重复打乱# figures4=random.sample(c[18:24],Number)    # 后6张不重复打乱# 9+9张不重复打乱图片合并figures=figures1+figures2# figures=figures1+figures2+figures3+figures4print(figures)# 每2个学号一组的列表 m名字里面的前两个数字(学号)name2=name[nn*2:nn*2+2]print(name2)for z in range(2):        # 5行组合循环2次 每页两张表# 单元格位置3*3格bg=[]# 前1+3+1行不要写入 从4动for x in range(0,2):        # 3行 索引1行2行3行for y in range(0,2):    # 3列 索引0列1列2列ww='{}{}'.format(x,y)bg.append(ww)print(bg) table = doc.tables[z]          for t in range(len(bg)):   # 02pp=int(bg[t][0:1])    qq=int(bg[t][1:2])  # print(p)               k=figures[z*4:z*4+4][t]         print(pp,qq,k)# 写入图片run=doc.tables[z].cell(pp,qq).paragraphs[0].add_run()        # 在第1个表格中第2个单元格内插入国旗run.add_picture('{}'.format(k),width=Cm(4.4),height=Cm(4.4))# 单元格宽度4.4   4.4table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.LEFT #居中 # 姓氏描画文字title=[]for t in range(4):title.append(name2[z][0])print(title)wz=[]# 前1+3+1行不要写入 从4动for x1 in range(0,2):        # 3行 索引1行2行3行for y1 in range(5,7):    # 3列 索引0列1列2列ww='{}{}'.format(x1,y1)wz.append(ww)print(wz) colour=[170,200,220,255]for t1 in range(len(wz)):   # 02pp1=int(wz[t1][0:1])    qq1=int(wz[t1][1:2])  # print(p)               k1=title[t1]         print(pp1,qq1,k1)# 第1个表的抬头# 写入序号和生肖名称run=table.cell(pp1,qq1).paragraphs[0].add_run(k1)    # 在单元格0,0(第1行第1列)输入第0个图图案run.font.name = '黑体'#输入时默认华文彩云字体# run.font.size = Pt(46)  #输入字体大小默认30号 换行(一页一份大卡片run.font.size = Pt(96)  #输入字体大小默认30号 一行里(可以一页两份)run.font.bold= False  #是否加粗run.font.color.rgb = RGBColor(colour[t1],colour[t1],colour[t1]) #数字小,颜色深0-255# paragraph.paragraph_format.line_spacing = Pt(180) #数字段间距r = run._elementr.rPr.rFonts.set(qn('w:eastAsia'), '黑体')#将输入语句中的中文部分字体变为华文行楷table.cell(pp1,qq1).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中   doc.save(r'C:\Users\jg2yXRZ\OneDrive\桌面\汉字姓氏拼图\零时Word\{}.docx'.format('%02d'%nn))   from docx2pdf import convert# docx 文件另存为PDF文件inputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/汉字姓氏拼图/零时Word/{}.docx".format('%02d'%nn)  # 要转换的文件:已存在outputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/汉字姓氏拼图/零时Word/{}.pdf".format('%02d'%nn)  # 要生成的文件:不存在# 先创建 不存在的 文件f1 = open(outputFile, 'w')f1.close()# 再转换往PDF中写入内容convert(inputFile, outputFile)print('----------第4步:把都有PDF合并为一个打印用PDF------------')# 多个PDF合并(CSDN博主「红色小小螃蟹」,https://blog.csdn.net/yangcunbiao/article/details/125248205)
import os
from PyPDF2 import PdfFileMerger
target_path =  'C:/Users/jg2yXRZ/OneDrive/桌面/汉字姓氏拼图/零时Word'
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/桌面/汉字姓氏拼图/(打印合集)汉字姓氏拼图A4一页两份(2乘2张)({}人共{}份).pdf".format(num,int(num/2)))
file_merger.close()
# doc.Close()# print('----------第5步:删除临时文件夹------------')    
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/汉字姓氏拼图/零时Word') #递归删除文件夹,即:删除非空文件夹

效果展示:

 

纸张裁剪:

 

 

 

 

 

 班级甲流关班了,五一节后再说把。

教学展示

时间:2023年5月24日 8:20-8:50

班级:中6

人数:22人

 本次创新形式——自选作业纸

    在做作业纸切割后,我发现,上面只有拼图片、底板、3个灰度汉字,没有地方标注“学号”。如果我来发作业,遇到相同姓氏的几个孩子,我自己很容易都搞混的某位孩子是否领取过。(没有学号或名字提示就是不方便)

所以我想试试让孩子自己来选自己的“姓氏”作业纸

一、幼儿自己选择自己的姓氏 

 

 

 

 

 

 

 

 

 

 

二、剪切拼图

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 作品展示:

 

 

 课后反思:

      本次活动的主要目的是:辨认自己的姓氏、2*2拼图拼贴、描灰色的大字和3个小字+独立画一个字。

1、找名字的经验:2/3幼儿可以从两个桌子上选出自己的姓氏(已熟悉名字的外形结构)。1/3幼儿还无法从一堆字里找到自己的姓氏。如1位幼儿拿同伴名字时,是倒置拿的,并问:“这是谁的名字?”

2、拼图的正确性:前期做过好几次拼贴,因此2*2的拼图相对简单,教师为5位幼儿摆放了2块图形位置。并为3位幼儿处理的粘错图块(旋转90),其余幼儿都是自己拼好的。

3、描字写字:一开始没有说,空格要写姓氏,所以很多孩子就再空格里“随便画“”——学号、图案、汉字都有。后来孩子都在这个格子的空隙里描了名字,有的孩子建议:“可以把学号写到大的字旁边”。还有4位孩子直接把学号、班级写在纸张方面。最终有2位孩子说不会写,但也被我“催着”描摹左侧的大字和小字。依样画葫芦“画”一个姓氏。

4、发放作业:中午饭后,我把拍过照片的纸片(左下角标了铅笔学号,因为5个姓氏相同)放在桌上,幼儿自己认领。几位识字的孩子凑在一起,根据姓氏、铅笔学号、记号笔学号,向同伴们分发他们的作品。

感悟:

1、幼儿自主领取个性化(个人信息)学具,提高参与活动兴趣。

2、自由活动时间,幼儿互助发放完成的作业。认识同伴的名字、学号。

这篇关于【教学类-34-04】20230422拼图(汉字姓氏-正方块拼图)2*2格子(中班主题《个别化拼图》偏语言)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/387703

相关文章

Go语言中make和new的区别及说明

《Go语言中make和new的区别及说明》:本文主要介绍Go语言中make和new的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 概述2 new 函数2.1 功能2.2 语法2.3 初始化案例3 make 函数3.1 功能3.2 语法3.3 初始化

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

Go语言代码格式化的技巧分享

《Go语言代码格式化的技巧分享》在Go语言的开发过程中,代码格式化是一个看似细微却至关重要的环节,良好的代码格式化不仅能提升代码的可读性,还能促进团队协作,减少因代码风格差异引发的问题,Go在代码格式... 目录一、Go 语言代码格式化的重要性二、Go 语言代码格式化工具:gofmt 与 go fmt(一)

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

Go语言中Recover机制的使用

《Go语言中Recover机制的使用》Go语言的recover机制通过defer函数捕获panic,实现异常恢复与程序稳定性,具有一定的参考价值,感兴趣的可以了解一下... 目录引言Recover 的基本概念基本代码示例简单的 Recover 示例嵌套函数中的 Recover项目场景中的应用Web 服务器中

Macos创建python虚拟环境的详细步骤教学

《Macos创建python虚拟环境的详细步骤教学》在macOS上创建Python虚拟环境主要通过Python内置的venv模块实现,也可使用第三方工具如virtualenv,下面小编来和大家简单聊聊... 目录一、使用 python 内置 venv 模块(推荐)二、使用 virtualenv(兼容旧版 P

Go语言中使用JWT进行身份验证的几种方式

《Go语言中使用JWT进行身份验证的几种方式》本文主要介绍了Go语言中使用JWT进行身份验证的几种方式,包括dgrijalva/jwt-go、golang-jwt/jwt、lestrrat-go/jw... 目录简介1. github.com/dgrijalva/jwt-go安装:使用示例:解释:2. gi