【教学类-32-04】20231013十二生肖4.0(标记+1位数字+排序+左右分类)(大班:《我是中国人》偏科学-数)

news2025/2/27 3:06:39

作品展示

一位数字、汉字对齐排列

 背景需求:

1、优化教案,参与比赛

10月份有一个幼儿园原创教案比赛,我把这个活动《十二生肖排排队》上报了。

2、把两位数序号改成一位数。

“老师,我觉得猴子最大,他是90”。

因为大班的孩子的镜像视力比较普遍,所以我最终决定把原来的01,02,……09改成1,2,3,4。

3.0版本(序号是2位数)

4.0版本(1-9是1位数,10-12是2位数)

‘’
3.序号位置对齐

数字有1位数和2位数,就会数字全部靠左,导致右侧汉字不对齐了。所以我让汉字位置一样,数字全部靠右。

3.0版本

4.0版本(图案居左,数字居中右侧,汉字全部在方框下面)

 作品展示

 1.0样式——动物头部方向全部向右,(A4竖版 2份)

2.0样式——动物头部方向随机向左、或者向右(A4竖版 2份)

3.0样式——动物头部方向随机向左、或者向右(A4横版 1份)——黑色线框、黑色图案,卡片大,看的清楚,公开课用

4.0样式(1位数,数字靠右,汉字靠右在方框下面)

素材准备:

1、图片准备

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

PPt -插入-图表

输入水果:

(只有一个,不够用) 

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

 龙(需要修图)

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

svg另存为png

 2、word准备:

 

 

 3、代码展示:代码


'''
十二生肖4.0(一页横版1份 动物朝向有的左侧、有的右侧)
目的:
1、属相做标记
2.十二生肖排序01-12
3、十二生肖分类(向左向右)
4、单位数学号

作者:阿夏
时间:2023年9月28日)

'''

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,num):    
    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\十二生肖\十二生肖(A4一份模板深色框).docx')
#     # 制作列表    
    for z in range(1):        # 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]
            k2=figures[t][-7:-4]
            if k2[0]=='0':
                k3='  '+k2[1]+'  '+k2[2:]
            else:
                k3=' '+k2[0:2]+'  '+k2[2:]

            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(4.),height=Cm(4.))
            table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.LEFT #居中  
            
            # 写入序号和生肖名称
            run=table.cell(pp,qq).paragraphs[0].add_run(k3)    # 在单元格0,0(第1行第1列)输入第0个图图案
            run.font.name = '黑体'#输入时默认华文彩云字体
            # run.font.size = Pt(46)  #输入字体大小默认30号 换行(一页一份大卡片
            run.font.size = Pt(39)  #输入字体大小默认30号 一行里(可以一页两份)
            run.font.bold= True  #是否加粗
            run.font.color.rgb = RGBColor(0,0,0) #数字小,颜色深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/桌面/十二生肖/(打印合集)十二生肖4.0上课左右图空格2({}人共{}份).pdf".format(num,num))
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个空格

 

  终端运行

 

  

 作品展示:

教学实践:

时间:2023年9月6日 15:10-15:45

班级:大6班

人数:16人

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

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

相关文章

关于Vue+webpack使用unocss编写CSS,打包后CSS没加前缀

关于Vuewebpack使用unocss编写CSS,打包后CSS没加前缀,封装了一个插件去解决了这个问题 unocss-postcss-webpack-plugin unocss在vite中使用配置,关于unocss在vite中使用,自行查阅官网 https://unocss.dev/integrations/vite ,vi…

Jetson ORIN NX安装Ubuntu20.04,配置CUDA,cuDNN 等注意事项

大体准备工作与流程与博客英伟达官方源Jetson Xavier NX安装Ubuntu20.04,配置CUDA,cuDNN,Pytorch等环境教程(基于NVIDIA官方教程,理论适用其它Jetson设备)一致,主要在步骤二、三处有一些区别&am…

专利分为哪些?如何查询一个公司的专利信息?

今天来分享专利的相关知识。 专利从字面上是指专有的权利和利益。“专利”一词来源于拉丁语Litterae patentes,意为公开的信件或公共文献,是中世纪的君主用来颁布某种特权的证明,后来指英国国王亲自签署的独占权利证书。专利在现代一般是由政…

湖南省政协副主席赖明勇一行莅临麒麟信安调研

10月11日下午,湖南省政协副主席、民建湖南省委会主委赖明勇,省政协提案委主任袁海平,民建省委会专职副主委、一级巡视员段安娜等长沙先进计算及信息安全产业调研组领导莅临麒麟信安调研国产操作系统企业发展情况。长沙市政府副市长彭涛&#…

Java 拷贝

Java 中的拷贝分为两种,浅拷贝和深拷贝,关于为什么要有两种拷贝方式而不是一种,就要涉及到 Java 的两种类型数据了。Java 的深浅拷贝都是针对于引用类型而言的,基本类型是没有深浅拷贝之分的,类似于 C 语言&#xff0c…

C# AnimeGAN 漫画风格迁移 动漫风格迁移 图像卡通化 图像动漫化

效果 项目 模型 animeganv3_H40_model.onnx animeganv3_H50_model.onnx animeganv3_H64_model.onnx AnimeGANv3_JP_face_v1.0.onnx AnimeGANv3_PortraitSketch_25.onnx Hayao-60.onnx Hayao_64.onnx Paprika_54.onnx Shinkai_53.onnx 下载 可执行文件exe下载 源码下载

element el-table树形表格结构,勾选联动 父级勾选,子级全部选中,勾选子级,父级显示勾选状态

需求实现如下 重点使用到 select 以及 select-all 两个方法 返回数据格式 代码实现 <el-table ref"tableRef" :cell-style"{ color: #FFF, background: #333 }":header-cell-style"{ color: #FFF, background: #333 }" row-key"id"…

操作系统 面试题(二)

PART1 1.乐观锁和悲观锁的区别是什么&#xff1f; 2.乐观锁和悲观锁的实现方式分别有哪些&#xff1f; 3.平均周转时间如何计算&#xff1f; 4.银行家算法是什么&#xff1f; 5.IO多路复用是什么&#xff1f; 6.HTTP的头部包含哪些内容&#xff1f; 7.TCP如何保持连接&a…

HTTP 原理与CND原理

1 HTTP 原理 HTTP是一个无状态的协议。无状态是指客户机&#xff08;Web浏览器&#xff09;和服务器之间不需要建立持久的连接&#xff0c;这意味着当一个客户端向服务器端发出请求&#xff0c;然后服务器返回响应(response)&#xff0c;连接就被关闭了&#xff0c;在服务器端…

NSA 和 CISA 揭示十大网络安全错误配置

美国国家安全局 (NSA) 和网络安全与基础设施安全局 (CISA) 在5日公布了其红蓝团队在大型组织网络中发现的十大最常见的网络安全错误配置。 通报还详细介绍了威胁行为者使用哪些策略、技术和程序 (TTP) 来成功利用这些错误配置来实现各种目标&#xff0c;包括获取访问权限、横向…

内存空间扩充之进程覆盖技术,交换技术

1.覆盖技术 人们引入了覆盖技术&#xff0c;用来解决“程序大小超过物理内存总和”的问题。 一个固定区&#xff1a; 存放最活跃的程序段固定区中的程序段在运行过程中不会调入调出 若干覆盖区&#xff1a; 不可能同时被访问程序段可共享一个覆盖区覆盖区中的程序段在运行…

MySQL慢查询的原因与解决方案

一、前言 在数据库系统中&#xff0c;慢查询是一个常见的问题。特别是在MySQL中&#xff0c;由于其复杂的查询结构和大量的数据&#xff0c;慢查询可能会导致系统性能下降&#xff0c;甚至影响整个应用的运行。本文将详细介绍MySQL慢查询的原因&#xff0c;并提供一些有效的解…

基于springboot实现火车订票管理系统项目【项目源码+论文说明】计算机毕业设计

摘要 本论文主要论述了如何使用JAVA语言开发一个火车订票管理系统 &#xff0c;本系统将严格按照软件开发流程进行各个阶段的工作&#xff0c;采用B/S架构&#xff0c;面向对象编程思想进行项目开发。在引言中&#xff0c;作者将论述火车订票管理系统的当前背景以及系统开发的…

免备案域名 DNS解析

1、注册购买域名地址&#xff08;免备案&#xff09; Name.com | Domain Names, Registration, Websites & Hosting 注意国家选中国区才可以使用支付宝&#xff0c;信息填写完之后创建账号&#xff0c;邮箱填写自己的邮箱 2、注册完登录账号进去找到Domain Name 搜索自动…

SOLIDWORKS® 2024 新功能 - 3D CAD

1、 先前版本的兼容性 • 利用您订阅的 SOLIDWORKS&#xff0c;可将您的 SOLIDWORKS 设计作品保存为旧版本&#xff0c;与使用旧版本 SOLIDWORKS 的供应商无缝协作。 • 可将零件、装配体和工程图保存为新版本前两年之内的SOLIDWORKS 版本。 优点&#xff1a; 即使其他用户正…

信息系统项目管理师第四版学习笔记——高级项目管理

项目集管理 项目集管理角色和职责 在项目集管理中涉及的相关角色主要包括&#xff1a;项目集发起人、项目集指导委员会、项目集经理、其他影响项目集的干系人。 项目集发起人和收益人是负责承诺将组织的资源应用于项目集&#xff0c;并致力于使项目集取得成功的人。 项目集…

Lego Studio打开solidworks零件/装配体 (sw另存obj文件)

solidworks 2020 Lego studio / part designer 截至2023-10-13&#x1f382;最新版 文章目录 操作步骤1&#xff09; solidworks 开启 ScanTo3D 功能2&#xff09; 零件 / 装配体 保存至stl格式文件3&#xff09; 以SanTo3D网格文件方式打开stl4&#xff09; 将打开的stl另存为…

港联证券:三季报亮相 盈利拐点来了?

10月12日&#xff0c;跟着黄山胶囊宣布深市2023年首份三季报&#xff0c;以及华辰装备宣布创业板首份三季报&#xff0c;第一批宣布三季报的A股公司增至5家。 Wind数据闪现&#xff0c;到10月12日记者发稿时&#xff0c;A股共有208家上市公司宣布了本年三季度成果预告&#xf…

基于 ACK Fluid 的混合云优化数据访问(五):自动化跨区域中心数据分发

作者&#xff1a;车漾 前文回顾&#xff1a; 本系列将介绍如何基于 ACK Fluid 支持和优化混合云的数据访问场景&#xff0c;相关文章请参考&#xff1a; -基于 ACK Fluid 的混合云优化数据访问&#xff08;一&#xff09;&#xff1a;场景与架构 -基于 ACK Fluid 的混合云优…

用wpf替代winform 解决PLC数据量过大页面卡顿的问题

winform 由于不是数据驱动, 页面想刷新数据必须刷新控件, wpf则不用. 可以利用wpf 的数据绑定和IOC, 页面中的消息传递, itemscontrol 实现大量数据刷新, 上位机页面不卡顿 代码如下: <Windowx:Class"NavTest.Views.NewMainView"xmlns"http://schemas.micr…