1、优化教案,参与比赛
10月份有一个幼儿园原创教案比赛,我把这个活动《十二生肖排排队》上报了。
2、把两位数序号改成一位数。
“老师,我觉得猴子最大,他是90”。16号同学大胆回答,然后他又停顿片刻“反过来又是09了”
因为大班的孩子的镜像视力的不规律性,普遍存在性。所以我最终决定把原来的01,02,……09改成1,2……9。
3.0版本(序号是2位数)
4.0版本(1-9是1位数,10-12是2位数)
‘’
3.序号位置对齐
数字有1位数和2位数,就会数字全部靠左,导致右侧汉字不对齐了。所以我让汉字位置一样,数字全部靠右。
3.0版本
4.0版本(图案居左,数字居中右侧,汉字全部在方框下面)
office PPT2013里面有一个图标的功能,内置大量矢量图(图片大小相等)
PPt -插入-图表
输入水果:
(只有一个,不够用)
输入动物(似乎看到了所有的十二生肖)
龙(需要修图)
把每个动物的图片另存为“XX.PNG"的样式
-
- '''
- 十二生肖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/桌面\十二生肖/十二生肖图片(序号+生肖+左侧)') #递归删除文件夹,即:删除非空文件夹
把图片的名称,拆分开来,插入1-2个空格
时间:2023年9月6日 15:10-15:45
班级:大6班
人数:16人