两列两列连连看
从小班到大班,幼儿都有关于“连线”的练习(手拉手做朋友、物品配对、标志连连看),预先用一uibot制作了A4一页8*4个(16组连连看图案)
思路:先从24个图案中随机抽取16个(有重复图形),插入到word第1-2列中(每列8个)然后将这随机抽取16个图案进行倒序排列,插入到word第3-4列中(每列8个)
(后续补图 )
由于使用了随机抽取,因此有大量的重复图形,而且是1、2列与3、4列之间进行混合连线,模拟实验了5为大班幼儿后,发现他们画的连线后,大量交叉在一起,根本搞不清是否正确。
(后续补图 )
于是提出了两个要求
在8*4的矩阵。24个图案需要抽取8*2=16个不重复的图案,16中的前8个插入word第1列,16中的后8个插入word第3列,第2列的数据就是第1列前8个图案的乱序不重复排列,第4列的数据就是第3列后8个图案的乱序不重复排列.
1、生成的PDF保存在这里——C:\Users\jg2yXRZ\OneDrive\桌面\连连看\
(没有“打印”文件夹也不影响)
2、py文件的位置( 放在电脑任意位置都不影响运行,我这里为了便于查找,放在D:/test下
- '''
- 作者:阿夏
- 时间:2022年11月4日连连看8*4)
- (A4竖排8*4张,纵向中间剪切))
- '''
-
- import os
-
- num=int(input('生成多少份\n'))
- Number=int(input('每页制作多少个(16个)\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
-
-
- for nn in range( 1,num+1): #多少份
- # word = gencache.EnsureDispatch('Word.Application')
- doc = Document()
- # doc = docx.Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\连连看\连连看Python模板.docx')# 打开带docx模板(这个模板有页脚的页码,阿夏认为页码是必须的)
- # 先随机抽取8个一列
- all=[]
- n1=[]
- n2=[]
- n = random.sample(list, Number) # 24个里面随机抽取16个放入一个组nn
- # print(n)
-
- for b1 in n[0:int(Number/2)]: # 16个里面的1-8个,提取单独数
- n1.append(b1) # 做第2列的乱序用
- all.append(b1) # 第1轮8个添入总列表 (插入Word第1列)
- # print(n1)
- # print(all)
-
- o1 = random.sample(n1, int(Number/2)) # 第1轮8个再随机打乱一次,不重复抽取
- for b in o1:
- all.append(b)#第1轮8个乱序排列不重复(插入Word第2列)
- # print(all)
-
- # # 以下代码用作第1列1-8图案,第2列8-1倒序排列
- # for bb in range(int(Number/2)-1,-1,-1):
- # print(bb)
- # all.append(n1[bb])#第1轮8个倒序排列不重复(插入Word第2列)
- # print(all)
-
- for b2 in n[int(Number/2):Number]: #16个里面的9-16个,提取单独数
- n2.append(b2) # 做第4列的乱序用
- all.append(b2) # 第2轮8个添入总列表 (插入Word第3列)
- # print(all)
-
- o2 = random.sample(n2, int(Number/2)) # 第1轮8个再随机打乱一次,不重复抽取
- for b in o2:
- all.append(b)#第1轮8个乱序排列不重复(插入Word第2列)
- # print(all)
-
- # # 以下代码用作第3列9-16图案,第4列16-9倒序排列
- # for bb in range(int(Number/2)-1,-1,-1):
- # print(bb)
- # all.append(n2[bb])#第1轮8个倒序排列不重复(插入Word第2列)
- # print(all)
-
- # 把all里面的所有元素输入到Word里
- for c in all: # 单个取值
- print(c)
- doc.add_paragraph(c)
- # 把内容按段落输入到doc这个docx文件内
- # 字体这一段一定要再写一次
- for paragraph in doc.paragraphs:
- for run in paragraph.runs:
- run.font.size = Pt(100) # 数字题目字体大小
- run.font.bold = False #数字题目字体是否加粗 不加粗,5*8再加粗比较满,压抑了
- run.font.name = 'Arial' # 控制是英文时的字体
- run.element.rPr.rFonts.set(qn('w:eastAsia'), '宋体') # 控制数字是中文时的字体
- # paragraph.alignment = WD_PARAGRAPH_ALIGNMENT.LEFT # 设置数字页眉居中对齐
- paragraph.alignment = WD_PARAGRAPH_ALIGNMENT.CENTER # 设置数字页眉居中对齐
- # paragraph.paragraph_format.line_spacing=1 #数字中文字的段行距
- paragraph.paragraph_format.line_spacing = Pt(90) #数字段间距
-
- # 设置主要页边距 5
- from docx.shared import Cm # 导入cm模块
- doc.sections[0].top_margin = Cm(0.7)# sections[1]是第二节=第二页 上边距
- doc.sections[0].bottom_margin = Cm(0.7)# sections[1]是第二节=第二页 下边距
- doc.sections[0].left_margin = Cm(0.7) # sections[1]是第二节=第二页 左边距
- doc.sections[0].right_margin = Cm(0.7)# sections[1]是第二节=第二页 右边距
- # 设置其他页边距
- doc.sections[0].gutter=Cm(0)# sections[1]是第二节=第二页 装订线 默认为0 左
- doc.sections[0].header_distance=Cm(1)# sections[1]是第二节=第二页 页眉边距
- doc.sections[0].footer_distance=Cm(1)# sections[1]是第二节=第二页 页脚边距
- # 装订线还有一个位置属性,暂时未发现如何设置,默认为左,如果需求设置成右,可以建个模板docx文档导入。
-
- # 设置纸张方向和大小 LANDSCAPE=横 PORTRAIT纵 默认信纸 纵
- from docx.shared import Cm # 导入CM #
- from docx.enum.section import WD_ORIENTATION # 导入纸张方向
- doc.sections[0].page_height = Cm(29.7) # 设置A4纸的高度
- doc.sections[0].page_width = Cm(21) # 设置A4纸的宽
- doc.sections[0].orientation = WD_ORIENTATION.LANDSCAPE # 设置纸张方向为横向 L
-
- # 设置分栏 如果不要,就把数字该为为1
- from docx.oxml.ns import qn
- doc.sections[0]._sectPr.xpath('./w:cols')[0].set(qn('w:num'), '4') #把第二节页设置为2栏
-
-
- # doc.Save()# 把有空格的1.docx保存
- 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({}份).pdf".format(int(Number/2),num))
- file_merger.close()
- # doc.Close()
-
- # print('----------第5步:删除临时文件夹------------')
- import shutil
- shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/连连看/零时Word') #递归删除文件夹,即:删除非空文件夹
-
1、运行代码需要输入的信息
生成Word和PDF过程中,会有一个“零时Word”文件夹“暂时出现。
零时Word”文件夹“里面的内容
30份全部生成后,“零时Word”文件夹会被删除,留下最后需要的打印合并PDf(30份随机的连连看)
1、图案的选择 24个不同的文字符号图案
2、确认4列中8个图案的排位,导入ALL列表
3、all里面的图案按预定计划写入Word的列,设置字体大小和段间距
4、页边距与分栏
运行时长:连连看8*4,30份,运行时长1分3秒
连连看8乘4_30份
(1)一般难度:可以整张A4发给幼儿对1与2、3与4列进行连线,
(2)低难度:也可以降低难度,12与34列中间剪开,幼儿做单列
(3)其他玩法:
《白天与黑夜》圈出所有和白天、黑夜有关的东西,(太阳、云朵、星星)
《不同的季节》圈出和春夏秋冬有关联的东西(雪人、太阳、花朵、火焰)
只是一种思路,因为线条集中在中心,教学意义不大,所以不作为学具使用。
2022年09月08日 中8班 随机5人