【教学类-33-02】食物加加加2.0版(3、4、5、10、15、20以内数字加法,随机抽数)

news2025/1/9 1:06:17

作品展示

3以内点数加法:加法最大值6

4以内点数加法:加法最大值8

背景需求:

幼儿在完成“5以内加法21题、5以内减法21题”时,有两个特点:

1、50%幼儿口算、另外50%不会做的孩子虽然画圈划圈,但更多还是习惯于手指点数。

2、幼儿不理解加号减号的意思,减法题也做成加法题。

以上,说明中班年龄段幼儿的水平应该处于“实物点数”的阶段,因此我希望把加法题的数字变成图形,便于幼儿直接直接点数,写数。同时在食物交换卡片1.0的学具中,每位孩子都能够根据食物图片的个数书写相应的数字,证明幼儿的点数正确率很高

因此这套学具的目的是——让幼儿了解“+号”与“-号”的意义:数量增加和数量减少、(有实物图片存在,暂时排除数字0的干扰选项)

材料准备:

1、PNG图片

 

2、WORD模板(横版)

代码执行

 本来只想用“水果图片”,后来发现水果太少了,随机起来会有重复,所以23种食物还是一起用了


#coding:utf-8
'''
目的:
1、2个苹果加3个苹果=
2、作者:阿夏
时间:2023年5月15日)

'''

import os
sum=int(input('每张卡片最大数字(3以内、4以内,5张以内、10张以内、15张以内,20以内)\n'))
size=float(input('图片尺寸(1.4,0.9,0.8,0.8,0.6,0.6)\n'))
num=int(input('生成多少份(28人)\n'))
Number=int(input('随机抽取几个图片(8个)\n'))
classroom=input('年级(输入“中”“大”)\n')

print('----------第1步:提取所有的扑克牌的路径------------')

path=[]
p=r"C:\Users\jg2yXRZ\OneDrive\桌面\水果加加加\水果加加加png"
# 过滤:只保留png结尾的图片
imgs=os.listdir(p)
for img in imgs:
    if img.endswith(".png"):
        path.append(p+'\\'+img)
# 所有图片的路径
print(path)
print(imgs)
# ['09苹果.png', '10橙子.png', '11樱桃.png', '12葡萄.png', '13西瓜.png', '14牛油果.png']

# print('----------第2步:新建一个临时文件夹------------')
# # 新建一个”装N份word和PDF“的文件夹
os.mkdir(r'C:\Users\jg2yXRZ\OneDrive\桌面\水果加加加\零时Word')


print('----------第3步:随机抽取12张图片 ------------')

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 random

import 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 qn

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


for nn in range(0,int(num/2)):    
    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\水果加加加\水果加加加(模板).docx')
    # 制作列表    
    for z in range(2):        # 5行组合循环2次 每页两张表
        table = doc.tables[z]
        # 第一行写入标题信息
        title=['{}以内随机数量'.format('%02d'%sum),'{}(   )班'.format(classroom)]
        zb=['00','02']
        
        for x in range(len(zb)):
            
            run=table.cell(int(zb[x][0]),int(zb[x][1])).paragraphs[0].add_run(title[x])   
            run.font.name = '微软雅黑'#输入时默认华文彩云字体
            run.font.size = Pt(15)  #输入字体大小默认30号
            run.font.color.rgb = RGBColor(200,200,200) #数字小,颜色深0-255
            # paragraph.paragraph_format.line_spacing = Pt(180) #数字段间距
            run.font.bold=True

            r = run._element
            r.rPr.rFonts.set(qn('w:eastAsia'), '微软雅黑')#将输入语句中的中文部分字体变为华文行楷
            table.cell(0,x).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中     

        # 23个图形随机抽取12个
        
        figure=random.sample(path,Number)    # 23个图片随机抽取8个图片(需要2次           
        print(figure)
        
        # 生成超过12的列表数量            
        figures=[]   
        s1=[]    

   
        # 随机倍数12次做个列表
        
        for w in range(len(figure)):
            for i in range(2):
                y =random.randint(1,sum)            # 1-8之间随机倍数的值 一个卡片的数量
                s1.append(y)             # 这是汇总倍数的列表
                # 随机乘以几份
                for e in range(y):
                    figures.append(figure[w])
        print(s1)
        # [2, 1, 1, 2, 4, 2, 3, 1, 2, 4, 2, 
        print(figures) 
        '''
#['C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\15糖果.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\15糖果.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物
# 图png\\09苹果.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\11樱桃.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\19蛋糕.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\ 
# 桌面\\水果加加加\\食物图png\\19蛋糕.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\22冰棍.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\22冰棍.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\22冰棍.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\22冰棍.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\21面包
# .png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\21面包.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\08寿司.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加
# \\食物图png\\08寿司.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\08寿司.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\01汉堡.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\10橙子.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\10橙子.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\23水果盘.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\23水果盘.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\23水果盘.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\水果加加加
# png\\23水果盘.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\02汉堡可乐.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\02汉堡可乐.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\05面条.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\05面条.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\05面条.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\05面条.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\水果加加加\\食物图png\\05面条.png']
'''
        
        # 单元格位置3*4格
        bg1=[]
        for x in range(1,9):        # 4行
            for y in range(0,3,2):    # 只要1列和3列
                    ww='{}{}'.format(x,y)
                    bg1.append(ww)
        print(bg1)   
        # ['00', '02', '10', '12', '20', '22', '30', '32', '40', '42', '50', '52', '60', '62', '70', '72']

        print(s1)
        # [2, 1, 1, 2, 4, 2, 3, 1, 2, 4, 2, 5]

        # 单元格倍数复制(如00格子里面要输入4个图片,所以00要复制4次)
        bg=[]  
        
        for s in range(len(bg1)):            
            for v in range(int(s1[s])):
                bg.append(bg1[s])
        print(bg)
            # ['00', '00', '01', '02', '10', '10', '11', '11', '11', '11', '12', '12', '20', '20', '20', '21', '22', '22', '30', '30', '30', '30', '31', '31', '32', '32', '32', '32', '32'] 


        table = doc.tables[z]          # 4567(8)行

        for t in range(len(bg)):   # 02
            pp=int(bg[t][0:1])    
            qq=int(bg[t][1:2])  
            # print(p)               
            k=figures[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(size),height=Cm(size))            # 1.5的图片最多6个
            table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.LEFT #居中  

           
   

                
    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/桌面/水果加加加/食物加法图 {}以内图片最大合计{} 食物加法图 {}人共{}份)(打印合集).pdf".format('%02d'%sum,'%02d'%(sum*2),num,int(num/2)))
file_merger.close()
# doc.Close()

# print('----------第5步:删除临时文件夹------------')    
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/水果加加加/零时Word') #递归删除文件夹,即:删除非空文件夹


终端运行:

 

 生成结果:

3以内:加法最大值6

4以内:加法最大值8

5以内:加法最大值10

10以内:加法最大值20

15以内:加法最大值30

 20以内:合计最大数量40

 感悟:

批量打印不同数量的卡片,增加难度,让幼儿感知“加号”的用法

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

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

相关文章

数据结构_图

目录 1. 图的基本概念 1.1 图的定义 1.1.1 有向图 1.1.2 无向图 1.1.3 简单图、多重图 1.1.4 完全图(也称简单完全图) 1.1.5 子图 1.1.6 连通、连通图和连通分量 1.1.7 强连通图、强连通分量 1.1.8 生成树、生成森林 1.1.9 顶点的度、入度和出…

MapReduce【自定义InputFormat】

MapReduce在处理小文件时效率很低,但面对大量的小文件又不可避免,这个时候就需要相应的解决方案。 默认的输入格式为TextInputFormat,对于小文件,它是按照它的父类FileInputFormat的切片机制来切片的,也就是不管一个文…

Java基础学习(17)网络编程

Java基础学习 一、 网络编程1.1 什么是网络编程1.2 常见的软件架构:1.3 网络编程的三要素1.4 IP1.4.1 InetAddress用法 1.5 端口号1.6 协议1.6.1 UDP协议1.6.1.1 UDP的三种通信方式 1.6.2 TCP协议1.6.2.1 TCP底层原理 一、 网络编程 1.1 什么是网络编程 解释&…

C++常用的支持中文的GUI库Qt 6之一:下载、安装与使用

C常用的支持中文的GUI库Qt 6之一:下载、安装与使用 因为Qt发展变化较快,网上许多介绍Qt的下载、安装与使用已过时,初学者常因行不通而受挫,故此发布本文,以Qt 6.2.4开源版在Windows 10安装与使用为例介绍。 C好用的GU…

DM8:达梦数据库宕机版本记录汇总(持续更新中)

DM8:达梦数据库宕机版本记录汇总(持续更新中) 环境介绍1 SQL引起的数据库故障1.1 SQL引起的数据库故障汇总表1.2 gdb dmserver core 调试得到数据库崩溃时的内存信息1.3 优化参数解决故障 环境介绍 在测试环境或生产环境,特别情况下会遇到数…

go tool pprof 参数 ‘-base‘ 和 ‘-diff_base‘ 之间的区别

go tool pprof 工具是用于分析由 runtime/pprof包 或 net/http/pprof包产生的profile数据,完整的帮助文档在 https://github.com/google/pprof/blob/main/doc/README.md ,pprof 工具支持的参数很多,可以用命令 go tool pprof --help来查看全部…

DJ5-4 交换局域网(第一节课)

目录 一、局域网概述 1、LAN 的特点和分类 2、常见的网络拓扑结构 二、计算机与局域网的连接 三、局域网体系结构 四、链路层寻址地址 1、MAC 地址分配 2、MAC 地址识别 五、ARP 地址解析协议 1、ARP 地址解析协议 2、ARP:两个主机位于同一个局域网 3、…

网络计算模式复习(六)

什么是CDN CDN的全称是Content Delivery Network,即内容分发网络。 其目的通过在现有的Internet中增加一层新的网络架构,将网站的内容发布到最接近用户的网络“边缘”,使用户可以就近取得所需的内容,解决Internet网络拥挤的状况&…

socket套接字通信 TCP传输控制协议/IP网络协议 5.18

B/S :浏览器和服务器 C/S :客户机和服务器 网络的体系结构: 网络的层次结构和每层所使用协议的集合 网络采用分层管理的方法,将网络的功能划分为不同的模块 OSI模型: 共7种: 应用层:接收用户的数据,面…

Blender基础技巧小结(三)

本文续签一篇:Blender基础技巧小结(二)_皮尔斯巴巴罗的博客-CSDN博客 将物体显示为模板,类似Maya Template 四窗口视图 调整3d视图远截面 Blender并不直接支持放样,可以用第三方插件,但效果并不好 基于me…

usb摄像头驱动打印信息

usb摄像头驱动打印信息 文章目录 usb摄像头驱动打印信息 在ubuntu中接入罗技c920摄像头打印的信息如下: [ 100.873222] usb 3-2: new high-speed USB device number 5 using xhci_hcd [ 101.230728] usb 3-2: New USB device found, idVendor046d, idProduct08e5 …

SpringMVC的拦截器(Interceptor)

文章目录 1 拦截器概念2 拦截器入门案例2.1 环境准备2.2 拦截器开发步骤1:创建拦截器类步骤2:配置拦截器类步骤3:SpringMVC添加SpringMvcSupport包扫描步骤4:运行程序测试步骤5:修改拦截器拦截规则步骤6:简化SpringMvcSupport的编写 3 拦截器参数3.1 前置处理方法3.2 后置处理方…

使用frp进行内网穿透(远程连接内网服务器)

文章目录 云服务购买服务器端(即我们购买的服务器)配置客户端(即我们自己的服务器)配置使用xshell登录远程服务器在服务器端设置frp开机自启动在客户端设置frp开机自启动 这里主要介绍使用frp工具进行内网穿透,适合的场…

Spring6和SpringBoot3的新特性-你不得不了解的AOT原来这么简单

Spring6.0新特性 一、Spring的发展历史 二、AOT AOT是Spring6.0提供的一个新特性,Ahead of Time 提前编译。 1.AOT概述 1.1 JIT和AOT的关系 1.1.1 JIT JIT(Just-in-time) 动态编译,即时编译,也就是边运行边编译,也就是在程序运…

LangChain与大型语言模型(LLMs)应用基础教程:角色定义

如果您还没有看过我之前写的两篇博客,请先看一下,这样有助于对本文的理解: LangChain与大型语言模型(LLMs)应用基础教程:Prompt模板 LangChain与大型语言模型(LLMs)应用基础教程:信息抽取 LangChain是大型语言模型(LLM)的应用框架,LangCha…

RK3568平台开发系列讲解(LCD篇)快速了解RK LCD的使用

🚀返回专栏总目录 文章目录 一、内核Config配置二、MIPI配置2.1 引脚配置2.2 背光配置2.3 显示时序配置2.3.1 Power on/off sequence2.3.2 Display-Timings三、EDP配置3.1 引脚配置3.2 EDP背光配置沉淀、分享、成长,让自己和他人都能有所收获!😄 📢 本篇章带大家快速了…

数据结构_查找

目录 1. 查找的基本概念 2. 顺序查找和折半查找 2.1 顺序查找 2.1.1 一般线性表的顺序查找 2.1.2 有序表的顺序查找 2.2 折半查找 2.3 分块查找 2.4 相关练习 3. 树型查找 3.1 二叉排序树 3.1.1 二叉排序树的定义 3.1.2 二叉排序树的查找 3.1.3 二叉排序树…

想要一个本地部署的海洋实景三维展示系统吗?

最近几年实景三维非常火,很多人包括博主都想将自己平时干的海洋测绘项目进行实景三维化,这样做的好处就是无论是管理数据还是成果展示都非常方便。我们可能会使用谷歌地图、奥维地图、图新地球等地图服务软件,它们也提供了一些测量、画图功和…

使用Hexo在Github上搭建个人博客

使用Hexo在Github上搭建个人博客 1. 安装Node和git2. 安装Hexo3. Git与Github的准备工作4. 将Hexo部署到Github5. 开始写作 1. 安装Node和git 在Mac上安装Node.js可以使用Homebrew,使用以下命令安装: brew install node使用以下命令安装Git: …

解决 Uncaught TypeError: SpriteCanvasMaterial is not a constructor.

文章目录 前言一、替代语法总结 前言 上周买了本《Three.js开发指南》, 第三版, 里面的语法不太跟趟, 有点旧, 倒也不能全怪作者, three迭代的确很快. 一、替代语法 这几天没事做, 加上前面本来就接触过Three, 很快进展到了第六章. 在推进 利用Canvas贴图给精灵(Sprite)增加样…