【教学类-28-01】AB型图案排序&涂色&手工-python 学具(中班:偏美术和数学)

效果展示

背景需求

1、纸张不够,缩小学具的面积

最近Python纸类学具用的频率高,主任给我的打印废纸都用光了o(╥﹏╥)o。

因此只能节省空间,设计一页A4的内容两个孩子用。

2、AB排序,永恒的数经验

上次中班一位老师提到需要AB排序类的学具,我给她一份涂色块的PDF,她说在分院没有彩色打印机。因此需要将彩色色块改成其他能够被打印的黑白图案。

结果:

将“规律填色的py"(AB色块涂色)的代码进行调整,设计图形(几何形、数字形)的ABAB排序学具

材料准备

1、word模板格式

  1. 图形准备

搜狗输入法-符号大全-特殊符号-空心几何图案(凑满12个)

搜狗输入法-符号大全-数字符号-带圈数字(凑满12个)

写两组列表

3、代码准备

# https://www.codenong.com/cs106022019/

'''

作者:阿夏
时间:2023年3月22日ABAB规律画几何形+填色竖版)
原理
# 一共10行,2份, 共用一个10*9表格
# 1-5行1份 1-2行是图形2个,3-4行是数字2个、第5行自己编
# 6-10行2份 6-7行是图形2个,8-9行是数字2个、第10行自己编

'''

from docx import Document
from docx.oxml.ns import nsdecls
from docx.oxml import parse_xml
import random,os
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

# 新建表行数
# rowsNum = int(input('行数(1行)\n'))
# 新建表列数
number = int(input('几个图案(只要2个=AB)\n'))# 填充几个格子AB=2个
hang=number*2
# rowrow= int(input('横向几条?(4)\n'))
num= int(input('生成多少份?\n'))



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


for nn in range(1,num+1):
    f1=['○','□','▽','☆','◇','△','◇','☾','♡','☼','♧','¤']# 几何形12个
    f2=['①','②','③','④','⑤','⑥','⑦','⑧','⑨','⑩','⑪','⑫']   # 数字圈10个
    
    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\AB图形填色\规律填色模板(竖版AB).docx')
    # 制作列表
    figure=[]
    for i in range(2):        # 5行组合循环2次
        figures1=random.sample(list(f1),hang)    # number=8几何形抽取2行,不重复的12个中的4个,
        figures2=random.sample(list(f2),hang)  # number=8数字圈抽取2行,不重复的12个中的4个,
        kong=''
        # 每页上面5行先组合里列表
        for h in figures1:
            figure.append(h)    # 1-2行几何形
        for g in figures2:
            figure.append(g)    # 3-4行数字圈
        for h1 in range(2):
            figure.append(kong)   # 5行空缺(幼儿自己填)
    print(figure) #    ['¤', '☆', '☼', '◇', '①', '⑧', '③', '⑤', '', '', '△', '□', '◇', '♧', '④', '⑤', '②', '⑥', '', '']

    
    # 单元格位置
    bg=[]
    for x in range(0,20,2):        # 里面有部分隐藏表格,1行3行5行……
        for y in range(0,number):                # 只要填充2个格子ABAB
                ww='{}{}'.format('%02d'%x,'%02d'%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[0]          # 4567(8)行

    for t in range(len(bg)):   # 02
        pp=int(bg[t][0:2])    
        qq=int(bg[t][2:4])  
        # print(p)               
        k=figure[t]  
        print(pp,qq,k)  
        
        run=table.cell(pp,qq).paragraphs[0].add_run(k)    # 在单元格0,0(第1行第1列)输入第0个图图案
        run.font.name = '黑体'#输入时默认华文彩云字体
        run.font.size = Pt(46)  #输入字体大小默认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\桌面\AB图形填色\零时Word\{}.docx'.format('%02d'%nn))   
    from docx2pdf import convert

    # docx 文件另存为PDF文件
    inputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/AB图形填色/零时Word/{}.docx".format('%02d'%nn)  # 要转换的文件:已存在
    outputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/AB图形填色/零时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/桌面/AB图形填色/零时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/桌面/AB图形填色/(打印合集)画图形+填色A4竖版2份AB({}份).pdf".format(num))
file_merger.close()
# doc.Close()

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

终端运行

作品位置

学具展示

操作说明:

这样28位孩子只用打印14份废纸就可以了。

1、模仿AB图案画后面的图形

2、自己画一个自创的AB图案

3、涂色

4、裁剪

5、粘贴成手串、长圈、拉拉圈等

  1. 纸圈任意位置写一个学号

存在问题:

模仿绘画得AB几何形图案有点难度

从幼儿操作角度来看,我发现几何形中的爱心、五角星、黑桃图案,并不是每位中班幼儿都能模仿绘画的。

处理方法——删除列表中的元素

因此需要剔除一些复杂得空心图案(保留 圆形、正方、倒三角、菱形、正三角、椭圆(希腊字母))

(搜狗和讯飞的符号中,几何空心图案比较少)

# https://www.codenong.com/cs106022019/

'''

作者:阿夏
时间:2023年3月22日ABAB规律画几何形+填色竖版)
原理
# 一共10行,2份, 共用一个10*9表格
# 1-5行1份 1-2行是图形2个,3-4行是数字2个、第5行自己编
# 6-10行2份 6-7行是图形2个,8-9行是数字2个、第10行自己编

'''

from docx import Document
from docx.oxml.ns import nsdecls
from docx.oxml import parse_xml
import random,os
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

# 新建表行数
# rowsNum = int(input('行数(1行)\n'))
# 新建表列数
number = int(input('几个图案(只要2个=AB)\n'))# 填充几个格子AB=2个
hang=number*2
# rowrow= int(input('横向几条?(4)\n'))
num= int(input('生成多少份?\n'))



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


for nn in range(1,num+1):
    f1=['○','□','▽','◇','△','Ο']# 简单几何形6个(1个希腊字母o)
    f2=['①','②','③','④','⑤','⑥','⑦','⑧','⑨','⑩','⑪','⑫']   # 数字圈10个
    
    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\AB图形填色\规律填色模板(竖版AB).docx')
    # 制作列表
    figure=[]
    for i in range(2):        # 5行组合循环2次
        figures1=random.sample(list(f1),hang)    # number=8几何形抽取2行,不重复的12个中的4个,
        figures2=random.sample(list(f2),hang)  # number=8数字圈抽取2行,不重复的12个中的4个,
        kong=''
        # 每页上面5行先组合里列表
        for h in figures1:
            figure.append(h)    # 1-2行几何形
        for g in figures2:
            figure.append(g)    # 3-4行数字圈
        for h1 in range(2):
            figure.append(kong)   # 5行空缺(幼儿自己填)
    print(figure) #    ['¤', '☆', '☼', '◇', '①', '⑧', '③', '⑤', '', '', '△', '□', '◇', '♧', '④', '⑤', '②', '⑥', '', '']

    
    # 单元格位置
    bg=[]
    for x in range(0,20,2):        # 里面有部分隐藏表格,1行3行5行……
        for y in range(0,number):                # 只要填充2个格子ABAB
                ww='{}{}'.format('%02d'%x,'%02d'%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[0]          # 4567(8)行

    for t in range(len(bg)):   # 02
        pp=int(bg[t][0:2])    
        qq=int(bg[t][2:4])  
        # print(p)               
        k=figure[t]  
        print(pp,qq,k)  
        
        run=table.cell(pp,qq).paragraphs[0].add_run(k)    # 在单元格0,0(第1行第1列)输入第0个图图案
        run.font.name = '黑体'#输入时默认华文彩云字体
        run.font.size = Pt(46)  #输入字体大小默认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\桌面\AB图形填色\零时Word\{}.docx'.format('%02d'%nn))   
    from docx2pdf import convert

    # docx 文件另存为PDF文件
    inputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/AB图形填色/零时Word/{}.docx".format('%02d'%nn)  # 要转换的文件:已存在
    outputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/AB图形填色/零时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/桌面/AB图形填色/零时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/桌面/AB图形填色/(打印合集)画简单图形+填色A4竖版2份AB({}份).pdf".format(num))
file_merger.close()
# doc.Close()

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

学具展示

打印问题(20230323):

习惯性生成28份(28人)

因此生成了28份PDF(实际是,56份学具)

全选打印,发现打印了很厚一堆纸、其中有8张纯白纸,为什么会多打印?怎么不是14份?

原来我生成了28份(页),因此全选打印后就是打印28页,而不是14页(28份)

也就是说,这种一页2套的学具,实际上只要生成总数的一半,也就是只要生成1-14页(14*2=28份)

对于这种一页2份的学具,在代码里直接将生成份数除以2,生成14份并打印,就不会过多打印,浪费纸张了。

# https://www.codenong.com/cs106022019/

'''

作者:阿夏
时间:2023年3月22日ABAB规律画几何形+填色竖版)
原理
# 一共10行,2份, 共用一个10*9表格
# 1-5行1份 1-2行是图形2个,3-4行是数字2个、第5行自己编
# 6-10行2份 6-7行是图形2个,8-9行是数字2个、第10行自己编

'''

from docx import Document
from docx.oxml.ns import nsdecls
from docx.oxml import parse_xml
import random,os
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

# 新建表行数
# rowsNum = int(input('行数(1行)\n'))
# 新建表列数
number = int(input('几个图案(只要2个=AB)\n'))# 填充几个格子AB=2个
hang=number*2
# rowrow= int(input('横向几条?(4)\n'))
num= int(input('生成多少份?\n'))



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


for nn in range(0,int(num/2)):#打印时只要28/2=14页
    f1=['○','□','▽','◇','△','Ο']# 简单几何形6个(1个希腊字母o)
    f2=['①','②','③','④','⑤','⑥','⑦','⑧','⑨','⑩','⑪','⑫']   # 数字圈10个
    
    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\AB图形填色\规律填色模板(竖版AB).docx')
    # 制作列表
    figure=[]
    for i in range(2):        # 5行组合循环2次
        figures1=random.sample(list(f1),hang)    # number=8几何形抽取2行,不重复的12个中的4个,
        figures2=random.sample(list(f2),hang)  # number=8数字圈抽取2行,不重复的12个中的4个,
        kong=''
        # 每页上面5行先组合里列表
        for h in figures1:
            figure.append(h)    # 1-2行几何形
        for g in figures2:
            figure.append(g)    # 3-4行数字圈
        for h1 in range(2):
            figure.append(kong)   # 5行空缺(幼儿自己填)
    print(figure) #    ['¤', '☆', '☼', '◇', '①', '⑧', '③', '⑤', '', '', '△', '□', '◇', '♧', '④', '⑤', '②', '⑥', '', '']

    
    # 单元格位置
    bg=[]
    for x in range(0,20,2):        # 里面有部分隐藏表格,1行3行5行……
        for y in range(0,number):                # 只要填充2个格子ABAB
                ww='{}{}'.format('%02d'%x,'%02d'%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[0]          # 4567(8)行

    for t in range(len(bg)):   # 02
        pp=int(bg[t][0:2])    
        qq=int(bg[t][2:4])  
        # print(p)               
        k=figure[t]  
        print(pp,qq,k)  
        
        run=table.cell(pp,qq).paragraphs[0].add_run(k)    # 在单元格0,0(第1行第1列)输入第0个图图案
        run.font.name = '黑体'#输入时默认华文彩云字体
        run.font.size = Pt(46)  #输入字体大小默认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\桌面\AB图形填色\零时Word\{}.docx'.format('%02d'%nn))   
    from docx2pdf import convert

    # docx 文件另存为PDF文件
    inputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/AB图形填色/零时Word/{}.docx".format('%02d'%nn)  # 要转换的文件:已存在
    outputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/AB图形填色/零时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/桌面/AB图形填色/零时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/桌面/AB图形填色/(打印合集)画简单图形+填色A4竖版2份AB({}页{}份).pdf".format(int(num/2),num))
file_merger.close()
# doc.Close()

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

材料位置

14页打印28份,就不会多打印了。(输入份数的数字建议是双数)

辐射引领

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿夏reasonsummer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值