【教学类-12-07】20221110《连连看 横版4*2*4(4套题目,适合小班)》(小班主题《娃娃家》)

 效果展示

背景需求:

前期对小班制作了适合的练练看,6*6版3套题。这是竖版的

如果制作横板的会怎么呢?

WORD表格制作(在横板A4)

把8*4表格,通过十字分割,变成4*2的连连看4套

代码设计:

'''

作者:阿夏
时间:2022年11月7日连连看(A4横板)4*2*4,四套题)
(A4横排8*4 4块分割 ))
'''

import os

num=int(input('生成多少份\n'))
Number=int(input('每页制作多少个(16个)\n'))
size=int(input('图案大小(8*4 建议65)\n'))
length=int(input('表格长度(8格)\n'))
weight=int(input('表格宽度(4格)\n'))

print('----------第1步:提取所有图案------------')
list=['✿','☸','✪','☁','➹','✈','☂','☃','◐','☼','☯','◎','❤','♨','☋','♘','★','♫','❀','〼','✉','☏','♕','♖']

print(len(list))# 一共24个图案

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


print('----------第3步:随机抽取8个不重复的图案 ------------')
import random
from win32com.client import constants,gencache
from win32com.client.gencache import EnsureDispatch
from win32com.client import constants # 导入枚举常数模块
import os,time

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


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

for z in range(0,num):   #多少份
    # word = gencache.EnsureDispatch('Word.Application')
    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\连连看\练练看框架模板4块分割.docx')  
    table = doc.tables[0]   
 
    # 先随机抽取8个一列  
    all=[]
    m1=[]
    m2=[]
    m3=[]
    m4=[]
    m5=[]
    m6=[]
    m7=[]
    m8=[]
    n = random.sample(list, Number)    # 24个里面随机抽取16个放入一个组nn
    # print(n) 
        

    # 第1行左4:
    for n1 in n[0:int(Number/4)]:     #   16个里面的1-4个,提取单独数
        m1.append(n1)
        all.append(n1)  # 第1轮8个添入总列表  (插入Word第1行)
    # print(all)

     # 第1行左4:
    for n2 in n[int(Number/4):int(Number/2)]:     #   16个里面的4-8个,提取单独数b
        m2.append(n2)
        all.append(n2)  # 第1轮8个添入总列表  (插入Word第1行)
    # print(all)
    
    # 第2行左4:
    o1 = random.sample(m1, int(Number/4))    # 第1轮8个再随机打乱一次,不重复抽取
    for b in o1:
        all.append(b)#第1轮8个乱序排列不重复(插入Word第2行)
    # print(all)

    # 第2行右4:
    o2 = random.sample(m2, int(Number/4))    # 第1轮8个再随机打乱一次,不重复抽取
    for b in o2:
        all.append(b)#第1轮8个乱序排列不重复(插入Word第2行)
    # print(all)

    # # 第3行左4:
    for n3 in n[int(Number/2):int(Number/4*3)]:     #   16个里面的1-4个,提取单独数
        m3.append(n3)
        all.append(n3)  # 第1轮8个添入总列表  (插入Word第1行)
    # print(all)

     # 第3行右边4:
    for n4 in n[int(Number/4*3):int(Number)]:     #   16个里面的4-8个,提取单独数b
        m4.append(n4)
        all.append(n4)  # 第1轮8个添入总列表  (插入Word第1行)
    # print(all)
    # 
    # 第4行左4:
    o3 = random.sample(m3, int(Number/4))    # 第1轮8个再随机打乱一次,不重复抽取
    for b in o3:
        all.append(b)#第1轮8个乱序排列不重复(插入Word第2行)
    # print(all)

    # 第4行右4:
    o4 = random.sample(m4, int(Number/4))    # 第1轮8个再随机打乱一次,不重复抽取
    for b in o4:
        all.append(b)#第1轮8个乱序排列不重复(插入Word第2行)
    print(all)
    # ['☃', '〼', '☂', '★', '☸', '♫', '☯', '➹', '☂', '〼', '☃', '★', '➹', '☸', '☯', '♫']

    #  确定8*4表格的表格单元格坐标(如第1行第1格是0,0 ,第2行第3格是(1,2)   
    bg=[]
    for x in range(0,weight):
        for y in range(0,length):
            ww='{}{}'.format(x,y)
            bg.append(ww)
    # print(bg)
    # ['00', '01', '02', '03', '04', '05', '06', '07', '10', '11', '12', '13', '14', '15', '16', '17', '20', '21', '22', '23', '24', '25', '26', '27', '30', '31', '32', '33', '34', '35', '36', '37']


    # 提取表格单元格坐标和图形的坐标
    for t in range(0,len(all)):             # 图案的长度为8*4=32个    遍历0-32(32个)
        pp=int(bg[t][0])          # 提取表格bg里面每个元素的第0个数字==单元格X坐标  t=索引数字
        qq=int(bg[t][1])          # 提取表格bg里面每个元素的第1个数字==单元格Y坐标  t=索引数字
        k=all[t]                  # 提取all图案列表里面每个图形  t=索引数字

        run=table.cell(pp,qq).paragraphs[0].add_run(k)    # 在单元格0,0(第1行第1列)输入第0个图图案
        run.font.name = '黑体'#输入时默认华文琥珀字体
        run.font.size = Pt(size)  #输入字体大小默认30号
        run.font.color.rgb = RGBColor(200,200,200) #设置颜色浅灰
        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'%(z+1)))#保存为XX学号的电话号码word     

    from docx2pdf import convert
    # docx 文件另存为PDF文件
    inputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/连连看/零时Word/{}.docx".format('%02d'%(z+1))# 要转换的文件:已存在
    outputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/连连看/零时Word/{}.pdf".format('%02d'%(z+1))  # 要生成的文件:不存在
    # 先创建 不存在的 文件
    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(int(Number/4),int(Number/8),int(Number/4),num))
file_merger.close()
# doc.Close()

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

重点说明:

终端运行

   图案列表的数量的提取方式

    图案列表的生成Word表格单元格坐标(XY)的索引数的生成(只有两行)

 如何将单个图案输入到指定的Word表格单元格内

效果再显示:

 存在问题:

1.优势:横板A4 另一种小班幼儿连连看。只有四个图案,线条不会混乱。

2.不足,随机抽取后,四个图案的乱序排列可能很少,有时候会出现,图案直接上下对应了。

教学活动照片展示:

  • 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、付费专栏及课程。

余额充值