【教学类-32-02】十二生肖2.0版(绘画+手工+排序+左右分类+玩牌)(中班:偏科学-数)

news2024/11/25 16:50:33

作品展示

2.0样式——动物头部方向随机向左、或者向右

背景需求

 1.0样式——动物头部方向全部向右,

我希望孩子分类的时候还能够“判断生肖头部的方向做一个左右分类”

素材准备:

 

1、图片准备

office PPT2013里面有一个图标的功能,内置大量矢量图(图片大小相等) 

PPt -插入-图表

输入水果:

(只有一个,不够用) 

输入动物(似乎看到了所有的十二生肖)

 龙(需要修图)

 把每个动物的图片另存为“XX.PNG"的样式

 

 2、word准备:

 

 

 3、代码展示:代码

'''
十二生肖2.0(一页2份 动物朝向有的左侧、有的右侧)
目的:
1、十二生肖涂色
2、十二生肖排序
3、十二生肖分类(向左向右)
作者:阿夏
时间:2023年4月15日)

'''

import os
from PIL import Image 

num=int(input('生成多少份28人\n'))
Number=int(input('随机抽取几个图片(12个)\n'))



print('----------第1步:提取右向图片的路径------------')

path_right=[]
pr=r"C:\Users\jg2yXRZ\OneDrive\桌面\十二生肖\十二生肖图片(序号+生肖+右侧)"
# 过滤:只保留png结尾的图片
imgs1=os.listdir(pr)
for img1 in imgs1:
    if img1.endswith(".png"):
        path_right.append(pr+'\\'+img1)
# 所有图片的路径
# print(path_right)
# ['C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+右侧)\\01鼠.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+右侧)\\02牛.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+右侧)\\03虎.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+右侧)\\04兔.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十
# 二生肖\\十二生肖图片(序号+生肖+右侧)\\05龙.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+右侧)\\06蛇.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片
# (序号+生肖+右侧)\\07马.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+右侧)\\08羊.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+右侧)\\09猴.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+右侧)\\10鸡.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+右侧)\\11狗.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+右侧)\\12猪.png']
# print(imgs1)
# # ['01鼠.png', '02牛.png', '03虎.png', '04兔.png', '05龙.png', '06蛇.png', '07马.png', '08羊.png', '09猴.png', '10鸡.png', '11狗.png', '12猪.png']

# 新建一个"左侧图片文件夹"
os.mkdir(r'C:\Users\jg2yXRZ\OneDrive\桌面\十二生肖\十二生肖图片(序号+生肖+左侧)')

# 制作左右翻转图片 # 再保存一个左边图片文件夹(图片左右翻转)
for i in range(len(path_right)):    # 12条路径
    tp = Image.open(path_right[i])      # 转换图片
    name=path_right[i][-7:]        # 提取图片名字"01鼠.png"
    tp.transpose(Image.FLIP_LEFT_RIGHT).save(r'C:\Users\jg2yXRZ\OneDrive\桌面\十二生肖\十二生肖图片(序号+生肖+左侧)\{}'.format(name))  # 左右翻转  

path_left=[]
pl=r"C:\Users\jg2yXRZ\OneDrive\桌面\十二生肖\十二生肖图片(序号+生肖+左侧)"
# 过滤:只保留png结尾的图片
imgs2=os.listdir(pl)
for img2 in imgs2:
    if img2.endswith(".png"):
        path_left.append(pl+'\\'+img2)
# 所有图片的路径
# print(path_left)
# ['C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+左侧)\\01鼠.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+左侧)\\02牛.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+左侧)\\03虎.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+左侧)\\04兔.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十
# 二生肖\\十二生肖图片(序号+生肖+左侧)\\05龙.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+左侧)\\06蛇.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片
# (序号+生肖+左侧)\\07马.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+左侧)\\08羊.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+左侧)\\09猴.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+左侧)\\10鸡.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+左侧)\\11狗.png', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\十二生肖\\十二生肖图片(序号+生肖+左侧)\\12猪.png']
# print(imgs2)

# 左边图片和右边图片的路径合并在一起
path_list=path_right+path_left
print(path_list)
print(len(path_list))# 24条路径


# from PIL import Image 
# tp = Image.open(r'D:\Desktop\22.png') 
# tp.transpose(Image.FLIP_TOP_BOTTOM).save(r'D:\Desktop\220.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次 每页两张表
        # 从左边图列表和右边图列表中抽取图片(12张图片,可能5个向左、7个向右边)
        # 24条里面0和12条是一组,2个里面随机抽1一个,1和13是一组,2个里面随机抽一个…… 抽出12个图片后
        r=[]
        t=[]
        for d in range(int(len(path_list)/2)):        # 24
            r.append(path_list[d])
            r.append(path_list[d+12])
            # print(s)
            t.append(random.choices(r))
            r.clear()
        # print(t) 
        # 去除[[],[],[]]    
        c=[]
        for o in t:
            for v in o:
                c.append(v)
        print(c)
               
       
        # 再打乱顺序读取12个      
        figures=random.sample(c,Number)    # 12个图片随机写入12个  
        print(figures)
        
        # 单元格位置3*4格
        bg=[]
        for x in range(0,4):        # 4行
            for y in range(0,3):    # 3列
                    ww='{}{}'.format(x,y)
                    bg.append(ww)
        print(bg)   
        # ['00', '01', '00', '01', '00', '01', '00', '01', '00', '01', '00', '01', '00', '01', '00', '01']

        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] 
            k2= figures[t][-7:-4]

            print(pp,qq,k)
            print(k2)  

            # 写入图片
            run=doc.tables[z].cell(pp,qq).paragraphs[0].add_run()        # 在第1个表格中第2个单元格内插入国旗
            run.add_picture('{}'.format(k),width=Cm(3),height=Cm(3))
            table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.LEFT #居中  
            
            # 写入序号和生肖名称
            run=table.cell(pp,qq).paragraphs[0].add_run(k2)    # 在单元格0,0(第1行第1列)输入第0个图图案
            run.font.name = '黑体'#输入时默认华文彩云字体
            # run.font.size = Pt(46)  #输入字体大小默认30号 换行(一页一份大卡片
            run.font.size = Pt(29)  #输入字体大小默认30号 一行里(可以一页两份)
            run.font.bold= True  #是否加粗
            run.font.color.rgb = RGBColor(200,200,200) #数字小,颜色深0-255
            # paragraph.paragraph_format.line_spacing = Pt(180) #数字段间距
            
            r = run._element
            r.rPr.rFonts.set(qn('w:eastAsia'), '黑体')#将输入语句中的中文部分字体变为华文行楷
            table.cell(pp,qq).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/桌面/十二生肖/(打印合集)十二生肖2.0左右图({}人共{}份).pdf".format(num,int(num/2)))
file_merger.close()
# doc.Close()

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

shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面\十二生肖/十二生肖图片(序号+生肖+左侧)') #递归删除文件夹,即:删除非空文件夹

4、代码重点:

 

 

  

 

 

 

 终端运行

 

  

 

 作品展示:

红色:动物头朝向左

黄色:动物头朝向右

 

 每一份(半张)的动物出现顺序都不一样、动物的头像方向也不同。

 幼儿操作内容:

裁剪前(描线涂色)

1、右上角小框里写学号(确认物权)

2、动物图案勾边(描图)、数字、文字勾边(描字)

3、动物身体内部涂色

4、剪卡片

裁剪后(排序、分类、互动玩牌)

5、排序(01-12):说说十二生肖的顺序(混个眼熟)

6、排序(动物大小):按动物大小排列(但幼儿不一定见过动物实际体型)

7-1 分类(头的朝向)向左的动物几只、向右的动物几只?

7、分类(2类):农场里的动物和非农场的动物(饲养,龙、虎、猴之外都有饲养)

8、分类(2类):会爬树的动物(猴、鼠、蛇)

9、分类(2类)):有角的动物(牛、羊、龙)

10、分类(3类)):吃草的(兔、羊、马、鸡、兔)、吃肉的(虎、猴、狗、蛇)、杂食(猪)

10、分类(3类):你最喜欢的动物,喜欢的动物,不喜欢的动物

11、玩牌1、2人互相抽牌、比大小(谁的数字大,谁就赢了)

12、玩牌2:那个动物体积大(这个幼儿不一定见过动物体型),大动物吃小动物

13、玩牌3:自己创造玩法规则

(游戏过程中,顺便认认生肖动物的汉字)

感悟:

虽然只是一个图片转向的需求,我也花了2个小时才搞出来。需要看PCK核心经验,然后查找更多的Python代码,实现“数、科学”方面的核心需求,

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

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

相关文章

java继承类怎么写

继承类是通过把父类的方法和属性继承到一个类中,而子类的方法和属性是子类自己定义的。 Java中有一个很重要的概念叫做继承,这也是 Java语言的精髓所在。Java语言提供了一种机制,叫做派生类。在 Java中,如果没有实现了某个派生类方…

终端和文件运行python代码

如何创建python文件?新建一个txt,然后修改后缀名为 .py, 然后修改打开方式为记事本,写入一行代码,然后关闭 接下来如何运行呢?让他输出这一段代码 winR cmd 回车 ,然后输入python 文件地址 我…

ChatGPT 未来的前景以及发展趋势

当谈到ChatGPT的未来和发展趋势时,需要考虑人工智能技术以及文本生成和交互的迅速发展。在这方面,ChatGPT的前景非常有希望,因为它是一种迄今为止最先进的人工智能技术之一。 ChatGPT是一种基于机器学习的自然语言处理技术,它能够…

MyBatis学习总结(四) MyBatis 延迟加载策略MyBatis 一级缓存、二级缓存MyBatis注解开发

MyBatis学习总结(四) MyBatis 延迟加载策略/MyBatis 一级缓存、二级缓存/MyBatis注解开发 一、 MyBatis 延迟加载策略 通过前面的学习,我们已经掌握了 MyBatis 中一对一(多对一)、一对多、多对多关系的配置及实现&am…

【Android入门到项目实战-- 5.1】—— 广播(一):接收系统广播

目录 一、什么是广播? 二、广播的类型 标准广播 有序广播 三、接收系统广播 1、动态注册监听网络变化 如何注册广播接收器? 2、静态注册实现开机启动 使用快捷方式创建广播接收器 实现开机广播 一、什么是广播? android广播机制就是…

全网最详细,Jmeter性能测试-性能进阶, 多协议实战Websocket/Dubbo(七)

目录:导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜)前言 Jmeter是目前主流的…

自行车及电动自行车出口美国GCC认证要求

所有进口商和美国本土制造商都必须签发普通合格证书(GCC)证明其产品符合具体规定要求。进口商和本土制造商应向认可的第三方实验室提交样品测试其产品是否符合相关安全法规。提供第三方实验室测试报告,合格证书由进口商和本土制造商提供。在外…

pytorch通过不同的维度提高cifar10准确率

各个维度通过模型通过优化器通过batchsize通过数据增强总结当前网络的博客上都是普遍采用某个迁移学习训练cifar10,无论是vgg,resnet还是其他变种模型,最后通过实例代码,将cifar的acc达到95以上,本篇博客将采用不同的维…

九龙证券|300亿空袭,港股吓懵了!

港股再度大幅回调,腾讯成了“导火索”。 当地时刻4月11日,腾讯大股东Prosus发布公告称拟再度进行回购,作为回购方案的一部分,Prosus本周将采纳行动,把9600万股腾讯股票以凭据方式移入香港中心结算系统,以便…

八、市场活动-创建

需求分析 用户在市场活动主页面,点击"创建"按钮,弹出创建市场活动的模态窗口; 用户在创建市场活动的模态窗口填写表单,点击"保存"按钮,完成创建市场活动的功能. *所有者是动态的(//在现实市场活动主页面时,就从数据库中查询出所有用户并且…

基于ChatGLM-6b+Streamlit+QDrant+DuckDuckGo搭建本地问答机器人及缓解时效性问题方案

本地部署chatglm及缓解时效性问题的思路: 模型使用chatglm-6b 4bit,推理使用hugging face,前端应用使用streamlit或者gradio。 微调对显存要求较高,还没试验。可以结合LoRA进行微调。 缓解时效性问题:通过本地数据库…

word页码从指定页开始,具体设置步骤

word页码从指定页开始,具体设置步骤1、在文档页面,以目录后第一页为页码开始页为例,也就是正文第一页,首先将鼠标光标定位到目录页最后的位置2、在【布局】选项下点击【分隔符】选项。3、在分隔符中选择【分节符】下的【下一页】。…

深度学习-第T4周——猴痘病识别

深度学习-第T4周——猴痘病识别深度学习-第T4周——猴痘病识别一、前言二、我的环境三、前期工作1、导入数据集2、查看图片数目3、查看数据四、数据预处理1、 加载数据1、设置图片格式2、划分训练集3、划分验证集4、查看标签2、数据可视化3、检查数据4、配置数据集五、搭建CNN网…

Day943.持续集成流水线 -系统重构实战

持续集成流水线 Hi,我是阿昌,今天学习记录的是关于持续集成流水线的内容。 从团队协作的角度上来看,在版本发布过程中,经常出现测试依赖开发手工生成制品、版本发布也从开发本地出版本的问题。而且项目架构如果从单体演进至组件…

MySQL-双主高可用

目录 🍁拓扑环境 🍁配置两台MySQL主主同步 🍃修改MySQL配置文件 🍃配置主从关系 🍃测试主主同步 🍁keepalived高可用 🍃keepalived的安装配置 🍃master配置 🍃slave配置 …

R -- 用psych包做因子分析

因子分析 因子分析又称为EFA,是一系列用来发现一组变量的潜在结构的办法。它通过寻找一组更小的,潜在的结构来解释已观测到的显式的变量间的关系。这些虚拟的、无法观测的变量称为因子(每个因子被认为可以解释多个观测变量间共有的方差&…

【回眸】ChatGPT Plus(GPT4体验卡)

前言 没忍住诱惑,开了个GPT4.0的会员,给大家表演一波 开通成功 开始问问题 写一个CNN疲劳驾驶监测代码,要求{使用Python语言,使用包,能成功运行,需要调用电脑摄像头,要求GUI界面有一些参数…

Python爬虫框架的介绍

爬虫框架的介绍Scrapy框架Crawley框架Portia框架Newspaper框架Python-goose框架随着网络爬虫的应用越来越多,一些爬虫框架逐渐涌现,这些框架将爬虫的一些常用功能和业务逻辑进行封装。这些框架的基础上,根据自己的需求添加少量的代码&#xf…

【操作系统 os学习笔记】

操作系统一、第一章:操作系统概述Ⅰ. 操作系统的基本概念1.操作系统的概念1.1 什么是操作系统?1.2 计算机系统的构成1.3 OS是一种系统软件1.4 OS作为系统软件,做了哪些事情2.操作系统的目标和功能2.1 目标2.2 功能3.操作系统的特征3.1 并发3.…

C#基础学习--接口

目录 什么是接口 ​编辑声明接口 实现接口 接口是引用类型 接口和as运算符 实现多个接口 实现具有重复成员的接口 多个接口的引用 派生成员作为实现 ​编辑显式接口成员实现 接口可以继承接口 什么是接口 接口是指定一组函数成员而不实现它们的引用类型 要实现一个接口…