【教学类-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语言使用slices包轻松实现排序功能

《Go语言使用slices包轻松实现排序功能》在Go语言开发中,对数据进行排序是常见的需求,Go1.18版本引入的slices包提供了简洁高效的排序解决方案,支持内置类型和用户自定义类型的排序操作,本... 目录一、内置类型排序:字符串与整数的应用1. 字符串切片排序2. 整数切片排序二、检查切片排序状态:

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细

如何合理管控Java语言的异常

《如何合理管控Java语言的异常》:本文主要介绍如何合理管控Java语言的异常问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍2、Thorwable类3、Error4、Exception类4.1、检查异常4.2、运行时异常5、处理方式5.1. 捕获异常

C语言中的常见进制转换详解(从二进制到十六进制)

《C语言中的常见进制转换详解(从二进制到十六进制)》进制转换是计算机编程中的一个常见任务,特别是在处理低级别的数据操作时,C语言作为一门底层编程语言,在进制转换方面提供了灵活的操作方式,今天,我们将深... 目录1、进制基础2、C语言中的进制转换2.1 从十进制转换为其他进制十进制转二进制十进制转八进制十进

$在R语言中的作用示例小结

《$在R语言中的作用示例小结》在R语言中,$是一个非常重要的操作符,主要用于访问对象的成员或组件,它的用途非常广泛,不仅限于数据框(dataframe),还可以用于列表(list)、环境(enviro... 目录1. 访问数据框(data frame)中的列2. 访问列表(list)中的元素3. 访问jav

C语言中位操作的实际应用举例

《C语言中位操作的实际应用举例》:本文主要介绍C语言中位操作的实际应用,总结了位操作的使用场景,并指出了需要注意的问题,如可读性、平台依赖性和溢出风险,文中通过代码介绍的非常详细,需要的朋友可以参... 目录1. 嵌入式系统与硬件寄存器操作2. 网络协议解析3. 图像处理与颜色编码4. 高效处理布尔标志集合

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

C 语言中enum枚举的定义和使用小结

《C语言中enum枚举的定义和使用小结》在C语言里,enum(枚举)是一种用户自定义的数据类型,它能够让你创建一组具名的整数常量,下面我会从定义、使用、特性等方面详细介绍enum,感兴趣的朋友一起看... 目录1、引言2、基本定义3、定义枚举变量4、自定义枚举常量的值5、枚举与switch语句结合使用6、枚

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印