【教学类-06-18】20231216 (按“列”正序题)X-Y之间“加法题+题”(1页最多0-13。不考虑空格补全)-CSDN博客文章浏览阅读102次。【教学类-06-18】20231216 (按“列”正序题)X-Y之间“加法题+题”(1页最多0-13。不考虑空格补全)https://blog.csdn.net/reasonsummer/article/details/135032151
【教学类-06-17】20231215 (小于55题,但填满55格)X-Y之间“加法题+题”-CSDN博客文章浏览阅读198次,点赞4次,收藏3次。【教学类-06-17】20231215 (题目填满55格)X-Y之间“加法题+题”https://blog.csdn.net/reasonsummer/article/details/135015012
遍历测试一下,发现0-13是105题,0-14就是120题超过115了。所以整页115格子时,只有0-13以下的减法或加法总数可以正好按正序写在所有的列里。
'''
X-Y 之间的所有加法题,竖列1页 补全多余空格 23*5=115题,
时间:2023年12月16日 21:46
作者:阿夏
'''
# 0-0之间的加法题共有 1 题
# 0-1之间的加法题共有 3 题
# 0-2之间的加法题共有 6 题
# 0-3之间的加法题共有 10 题
# 0-4之间的加法题共有 15 题
# 0-5之间的加法题共有 21 题
# 0-6之间的加法题共有 28 题
# 0-7之间的加法题共有 36 题
# 0-8之间的加法题共有 45 题
# 0-9之间的加法题共有 55 题
# 0-10之间的加法题共有 66 题
# 0-11之间的加法题共有 78 题
# 0-12之间的加法题共有 91 题
# 0-13之间的加法题共有 105 题
# 以上用模板一
# 0-14之间的加法题共有 120 题
# 0-15之间的加法题共有 136 题
# 0-16之间的加法题共有 153 题
# 0-17之间的加法题共有 171 题
# 0-18之间的加法题共有 190 题
# 0-19之间的加法题共有 210 题
# 0-20之间的加法题共有 231 题
# 以上用模板二
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('打印几份(根据人数32人)\n'))
classroom=input('班级(输入中、大)\n')
size=20
height1=23
weight1=5
gz=height1*weight1 # 115
sum1=int(input('X-Y以内的“+” 最小数字X(0)\n'))
sum2=int(input('X-Y以内的“+” 最大数字Y=(13)\n'))
'''
2位数去0 0-20所有加法,从小到大排序(0+1,0+2,而不是0+1,0+10)
作者:阿夏
时间:2023年11月26日 12:00
'''
# 5以内“+”题共21题
P1=[]
for a in range(0,sum2+1): # 起始数字就是10,就是排除掉0-10之间的数字
for b in range(0,sum2+1): # 起始数字为0,
if 0<=a+bgz:
title='{}-{}“+”正序共{}抽{}题'.format(sum1,sum2,len(P),gz)
d=['0001','0002']
# 表格0 表格2的 03 05单元格里写入标题信息c
A.append(c)
A.append(title)
print(A)
# 制作"单元格"
d=['0001','0002']
bg=[]
for x in range(0,weight1): # 5 #数列 先宽 后高
for y in range(1,height1+1): # 23
s1='{}{}'.format('%02d'%y,'%02d'%x) #数列 先y 后x
bg.append(s1)
print(bg)
print(len(bg))
bg.insert(0,d[1])
bg.insert(0,d[0])
print(bg)
print(len(bg))
# # 制作"单元格"
# bgall=[]
# # for bb in d:
# # bgall.append(bb)
# for x in range(0,weight1): # 5 #数列 先宽 后高
# for y in range(1,height1+1): # 23
# s1='{}{}'.format('%02d'%y,'%02d'%x) #数列 先y 后x
# bgall.append(s1)
# print(bgall)
# print(len(bgall))
# # 不同情况下的单元格数量
# # if len(P) <=gz:
# # bg=bgall[0:2+len(gz)]
# # 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) # 若图片文件夹不存在就创建
D=[]
for z in range(0,num): #多少份
# 标题说明
# 新建word
doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\03加减法竖版所有题目1页.docx')
for j in range(1):
# 如果题目总数小于155,就提取
# 例如:0-5 21题,P的第一部分是21题全部,第2部分就21题里面的随机抽屉,第3部分13也是随机抽取,可能会重复
PP=[]
PPP=[]
PP.clear()
# P.clear()
if len(P)<=gz:
for l in P : # 先写入固定的21题
PP.append(l)
print(PP)
print('第1组长度{}'.format(len(PP)))
# 0-0只有1题,所以批量155次
for e in range(gz):
PP.append('') # 预留一个空行做分割线
w=random.sample(P,len(P)) # 从21题随机抽取不重复21
for u in w: # 遍历提取
PP.append(u) # 添加到P
PPP=PP[:gz] # 提取前55个
print('把21题批量55次后,总数量 实际提取{}格{}'.format(len(PP),len(PPP)))
print(PPP)
else:
w=random.sample(P,len(P)) # 从21题随机抽取不重复21
PPP=w
PPP.insert(0,title)
PPP.insert(0,classroom)
print(PPP)
print(len(PPP))
# # 房间模板(第一个表格)要写入的门牌号列表
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(PPP[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.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 PdfMerger
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 = PdfMerger()
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,num))
else:
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)01“+”(一页两份 ){}题{}-{}之间正序数列排空“+”共{}题抽{}题({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P),gz, c,num,num))
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word') #递归删除文件夹,即:删除非空文件夹
用到了2位数去0,否则0+0后面就是0+10.