【教学类-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

相关文章

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验