在大四班里,预测试55格“5以内、10以内、20以内的加法题、减法题、加减混合题”的“实用性”。
现场发现,只打印一份20以内加法减法混合题。
“这套20以内的加减法最难,谁会做?”(摸底幼儿的水平)
有两位男孩举手想挑战,其中一位顽皮男孩之前就撒娇祈求要最难的题目,我就同意给他让他试试了。
他做了几题后,又拿着纸,点着一道题问我:“X老师,你不是说这是20以内加减法吗,为什么这里会有3+0的题目?”
我一愣,说:“20以内自然包含了3以内的题目。3以内题目对你来说,不是很容易”
他不明所以,但还是点点头走了。
我转眼一想,他的意思大概是:“20以内不应该包含3+0、4-4=这种一位数相加的简单题目,应该至少有一个两位数的数字,如10+5=、12+4=、”
1.用代码先测试一下“X—X之间加法题”的数量
1.0版本中的“0-5以内加法”、“0-10以内加法”、“0-20以内加法”,
起始数字5与0-20之间数字的题目数
起始数字10与0-20之间数字的题目数
关键数字测试后,我发现一个现象
1、0-5 21题,5-10 51题,10-15 81题,
结论:相隔5个数(实际6个),30循环递增数量
2、0-10 66题、10-20 176题、20-30 286题
结论:相隔10个数(实11个),110循环递增数量
2、0-Y都是有题目数的,X-Y会出现0题
结论:需要在排除0题,如if x=0,pass。也因此可以看到,题目数数量难以确定,不能用大于9、小于9作为判断单元格抽取数量的标准,需要用len(P)<=55(单元格数量)、len(P)>55(单元格数量)替代
3、项目标题从“X以内加减题共XX题抽XX”改成“X-Y之间“+”共XX题抽XX”
'''
X-Y 之间的加法题(如10-20之间的所有加法,第一个数字从10开始,)
时间:2023年11月24日 21:46
作者:阿夏
'''
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
# 第一步:制作不重复所有“+”、不重复所有减法
# 不重复的数字题
num=int(input('打印几份(必须是双数)\n'))
classroom=input('班级(输入中、大)\n')
size=20
height1=12
weight1=5
sum1=int(input('X-Y以内的“+” 最小数字X\n'))
sum2=int(input('X-Y以内的“+” 最大数字Y\n'))
for sum in [sum2]:
# 5以内“+”题共21题
P=[]
for a in range(sum1,sum2+1): # 起始数字就是10,就是排除掉0-10之间的数字
for b in range(0,sum2+1): # 起始数字为0,
if sum1<=a+b55:
title='{}-{}“+”共{}抽55题'.format(sum1,sum2,len(P))
d=['0001','0002']
# 表格0 表格2的 03 05单元格里写入标题信息c
D.append(c)
D.append(title)
print(D)
# 制作"单元格"
bgall=[]
for bb in d:
bgall.append(bb)
for x in range(1,height1):
for y in range(0,weight1):
s1='{}{}'.format('%02d'%x,'%02d'%y) # 数字加空格
bgall.append(s1)
print(bgall)
print(len(bgall))
# 不同情况下的单元格数量
if len(P) <=55:
bg=bgall[0:2+len(P)]
print(bg)
print(len(bg))
else:
bg=bgall[0:len(bgall)]
print(bg)
print(len(bg))
# ['0003', '0005', '0100', '0101', '0102', '0103', '0104', '0200', '0201', '0202', '0203', '0204', '0300', '0301', '0302', '0303', '0304', '0400', '0401', '0402', '0403', '0404', '0500']
# 新建一个”装N份word和PDF“的临时文件夹
imagePath1=r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\零时Word'
if not os.path.exists(imagePath1): # 判断存放图片的文件夹是否存在
os.makedirs(imagePath1) # 若图片文件夹不存在就创建
n=int(num/2)
for z in range(0,n): #多少份
# 标题说明
# 新建word
doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\01加减法模板一页两份(加减法,大量题目).docx')
for j in range(2):
if len(P) <=55:
# D=[]
# 小于9的题目,要计算一共有几题,写入等量的单元格内,
C=random.sample(P,len(P))
for cc in C:
D.append(cc)
print(D)
print(len(D))
else:
# D=[]
# 大于9的题目,只要抽取55题,多余的写不下,
C=random.sample(P,len(bgall)) # 55格
for cc in C:
D.append(cc)
print(D)
print(len(D))
# # 房间模板(第一个表格)要写入的门牌号列表
table = doc.tables[j] # 表0,表2 写标题用的
# 标题写入3、5单元格
for t in range(0,len(bg)): # 0-5是最下面一行,用来写卡片数字
pp=int(bg[t][0:2]) #
qq=int(bg[t][2:4])
k=str(D[t]) # 提取list图案列表里面每个图形 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.size = Pt(size) #是否加粗
run.font.color.rgb = RGBColor(200,200,200) #数字小,颜色深0-255
run.bold=True
# 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.LEFT #居中
#
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)
if len(P) <=55:
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)01“+”(一页两份 )55题{}-{}之间“+”共{}题抽{}题({}共{}人打印{}张).pdf" .format('%02d'%sum1,'%02d'%sum2,'%03d'%len(P),'%02d'%len(P),c,num,n))
else:
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)01“+”(一页两份 )55题{}-{}之间“+”共{}题抽55题({}共{}人打印{}张).pdf".format('%02d'%sum1,'%02d'%sum2,'%03d'%len(P),c,num,n))
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word') #递归删除文件夹,即:删除非空文件夹
但这里面是缺了另外一部分的题目,并不是完全意义的10-20之间所有的加法题,所以我又为P里面增加了另外一半题目。(B类)
'''
X-Y 之间的所有加法题(如10-20之间的所有加法,10+0,10+1,……20+,0,然后是0+10,1+9,出现132个题目,去重后131个)
时间:2023年11月24日 21:46
作者:阿夏
'''
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
# 第一步:制作不重复所有“+”、不重复所有减法
# 不重复的数字题
num=int(input('打印几份(必须是双数)\n'))
gz=int(input('一共几个单元格(55个)\n'))
classroom=input('班级(输入中、大)\n')
size=20
height1=12
weight1=5
sum1=int(input('X-Y以内的“+” 最小数字X\n'))
sum2=int(input('X-Y以内的“+” 最大数字Y\n'))
for sum in [sum2]:
# 5以内“+”题共21题
P=[]
for a in range(0,sum+1): # 起始数字就是10,就是排除掉0-10之间的数字
for b in range(0,sum+1): # 起始数字为0,
if sum1<=a+bgz:
title='{}-{}“+”共{}抽55题'.format(sum1,sum2,len(P))
d=['0001','0002']
# 表格0 表格2的 03 05单元格里写入标题信息c
D.append(c)
D.append(title)
print(D)
# 制作"单元格"
bgall=[]
for bb in d:
bgall.append(bb)
for x in range(1,height1):
for y in range(0,weight1):
s1='{}{}'.format('%02d'%x,'%02d'%y) # 数字加空格
bgall.append(s1)
print(bgall)
print(len(bgall))
# 不同情况下的单元格数量
if len(P) <=gz:
bg=bgall[0:2+len(P)]
print(bg)
print(len(bg))
else:
bg=bgall[0:len(bgall)]
print(bg)
print(len(bg))
# ['0003', '0005', '0100', '0101', '0102', '0103', '0104', '0200', '0201', '0202', '0203', '0204', '0300', '0301', '0302', '0303', '0304', '0400', '0401', '0402', '0403', '0404', '0500']
# 新建一个”装N份word和PDF“的临时文件夹
imagePath1=r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\零时Word'
if not os.path.exists(imagePath1): # 判断存放图片的文件夹是否存在
os.makedirs(imagePath1) # 若图片文件夹不存在就创建
n=int(num/2)
for z in range(0,n): #多少份
# 标题说明
# 新建word
doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\01加减法模板一页两份(加减法,大量题目).docx')
for j in range(2):
if len(P) <=gz:
# D=[]
# 小于9的题目,要计算一共有几题,写入等量的单元格内,
C=random.sample(P,len(P))
for cc in C:
D.append(cc)
print(D)
print(len(D))
else:
# D=[]
# 大于9的题目,只要抽取55题,多余的写不下,
C=random.sample(P,len(bgall)) # 55格
for cc in C:
D.append(cc)
print(D)
print(len(D))
# # 房间模板(第一个表格)要写入的门牌号列表
table = doc.tables[j] # 表0,表2 写标题用的
# 标题写入3、5单元格
for t in range(0,len(bg)): # 0-5是最下面一行,用来写卡片数字
pp=int(bg[t][0:2]) #
qq=int(bg[t][2:4])
k=str(D[t]) # 提取list图案列表里面每个图形 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.size = Pt(size) #是否加粗
run.font.color.rgb = RGBColor(150,150,150) #数字小,颜色深0-255
run.bold=True
# 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.LEFT #居中
#
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)
if len(P) <=gz:
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)01“+”(一页两份 ){}题{}-{}之间正逆“+”共{}题抽{}题({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P),'%02d'%len(P),c,num,n))
else:
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)01“+”(一页两份 ){}题{}-{}之间正逆“+”共{}题抽55题({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P),c,num,n))
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word') #递归删除文件夹,即:删除非空文件夹
'''
X-Y 之间的所有加法题(如10-20之间的所有加法,10+0,10+1,……20+,0,然后是0+10,1+9,出现132个题目,去重后131个)
时间:2023年11月24日 21:46
作者:阿夏
'''
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
# 第一步:制作不重复所有“+”、不重复所有减法
# 不重复的数字题
num=int(input('打印几份(必须是双数)\n'))
gz=int(input('一共几个单元格(55个)\n'))
classroom=input('班级(输入中、大)\n')
size=20
height1=12
weight1=5
sum1=int(input('X-Y以内的“+” 最小数字X\n'))
sum2=int(input('X-Y以内的“+” 最大数字Y\n'))
for sum in [sum2]:
# 5以内“+”题共21题
P=[]
for a in range(0,sum+1): # 起始数字就是10,就是排除掉0-10之间的数字
for b in range(0,sum+1): # 起始数字为0,
if sum1<=a+bgz:
title='{}-{}“+”共{}抽55题'.format(sum1,sum2,len(P))
d=['0001','0002']
# 表格0 表格2的 03 05单元格里写入标题信息c
D.append(c)
D.append(title)
print(D)
# 制作"单元格"
bgall=[]
for bb in d:
bgall.append(bb)
for x in range(1,height1):
for y in range(0,weight1):
s1='{}{}'.format('%02d'%x,'%02d'%y) # 数字加空格
bgall.append(s1)
print(bgall)
print(len(bgall))
# 不同情况下的单元格数量
if len(P) <=gz:
bg=bgall[0:2+len(P)]
print(bg)
print(len(bg))
else:
bg=bgall[0:len(bgall)]
print(bg)
print(len(bg))
# ['0003', '0005', '0100', '0101', '0102', '0103', '0104', '0200', '0201', '0202', '0203', '0204', '0300', '0301', '0302', '0303', '0304', '0400', '0401', '0402', '0403', '0404', '0500']
# 新建一个”装N份word和PDF“的临时文件夹
imagePath1=r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\零时Word'
if not os.path.exists(imagePath1): # 判断存放图片的文件夹是否存在
os.makedirs(imagePath1) # 若图片文件夹不存在就创建
n=int(num/2)
for z in range(0,n): #多少份
# 标题说明
# 新建word
doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\01加减法模板一页两份(加减法,大量题目).docx')
for j in range(2):
if len(P) <=gz:
# D=[]
# 小于9的题目,要计算一共有几题,写入等量的单元格内,
C=random.sample(P,len(P))
for cc in C:
D.append(cc)
print(D)
print(len(D))
else:
# D=[]
# 大于9的题目,只要抽取55题,多余的写不下,
C=random.sample(P,len(bgall)) # 55格
for cc in C:
D.append(cc)
print(D)
print(len(D))
# # 房间模板(第一个表格)要写入的门牌号列表
table = doc.tables[j] # 表0,表2 写标题用的
# 标题写入3、5单元格
for t in range(0,len(bg)): # 0-5是最下面一行,用来写卡片数字
pp=int(bg[t][0:2]) #
qq=int(bg[t][2:4])
k=str(D[t]) # 提取list图案列表里面每个图形 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.size = Pt(size) #是否加粗
run.font.color.rgb = RGBColor(150,150,150) #数字小,颜色深0-255
run.bold=True
# 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.LEFT #居中
#
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)
if len(P) <=gz:
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)01“+”(一页两份 ){}题{}-{}之间正逆“+”共{}题抽{}题({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P),'%02d'%len(P),c,num,n))
else:
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)01“+”(一页两份 ){}题{}-{}之间正逆“+”共{}题抽55题({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P),c,num,n))
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word') #递归删除文件夹,即:删除非空文件夹
随机测试X-Y的范围
X-Y之间的加法题,出现的数量难以预估,所以需要len(p)>55,来抽取相应的单元格坐标。
200,200,200的灰色打印很浅,所以调的更黑些,便于幼儿观察(能够做题的幼儿不需要描数字,不会写数字的孩子写这么小的题目数字,手指控制并不方便,可以写对大号数字进行描红)
2.0题目数字颜色灰度,看的更清楚