作品展示:
背景需求:
【教学类-06-12】20231202 0-9数字分合-房屋样式(一)-下右空-升序-抽7题-CSDN博客文章浏览阅读102次。【教学类-06-12】20231202 0-9数字分合-房屋样式-下右空-升序https://blog.csdn.net/reasonsummer/article/details/134750697?spm=1001.2014.3001.5501前文提到了此代码只能做房屋分合的右侧列空
解决:
微调代码,将左侧列空和右侧列空放在一个代码里,可以选择。
WORD样式-无下划线
代码展示
'''
2-9之间随机抽取7个数字-房屋分合题-合-空在左侧and空在右侧,房屋
时间:2023年12月02日 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'))
zyk=int(input('输入数字,左空=1,右空=2)\n'))
tm=7 # 只能抽取7题
# classroom=input('班级(输入中、大)\n')
size=20
# height1=
# weight1=5
sum1=int(input('X-Y以内的最小数字X(0-9)\n'))
sum2=int(input('X-Y以内的最大数字Y(0-9)\n'))
print('-----------第1步 制作基础题型-----------')
# 5以内“+”题共21题
P=[]
P1=[]
LIST=[]
for l in range(sum1,sum2+1):
P.clear()
# Q.clear()
for a in range(0,sum2+1): # 起始数字就是10,就是排除掉0-10之间的数字
for b in range(0,sum2+1): # 起始数字就是10,就是排除掉0-10之间的数字
if a+b==l:
P.append('{}'.format(a) )
P.append('{}'.format(b) )
# P1.append('{}+{}={}'.format(a,b,l) )
# P1.append('{}+{}={}'.format(b,a,l) )
else:
pass
Q =list(set(P)) # 排除重复,但随机打乱
Q.sort() # 小到大排序
# print(Q)
LIST.append(Q)
for x in LIST:
print(x)
# ['0+0=0']
# ['0+1=1', '1+0=1']
# ['0+2=2', '1+1=2', '2+0=2']
# ['0+3=3', '1+2=3', '2+1=3', '3+0=3']
# ['0+4=4', '1+3=4', '2+2=4', '3+1=4', '4+0=4']
# ['0+5=5', '1+4=5', '2+3=5', '3+2=5', '4+1=5', '5+0=5']
# ['0+6=6', '1+5=6', '2+4=6', '3+3=6', '4+2=6', '5+1=6', '6+0=6']
# ['0+7=7', '1+6=7', '2+5=7', '3+4=7', '4+3=7', '5+2=7', '6+1=7', '7+0=7']
# ['0+8=8', '1+7=8', '2+6=8', '3+5=8', '4+4=8', '5+3=8', '6+2=8', '7+1=8', '8+0=8']
# ['0+9=9', '1+8=9', '2+7=9', '3+6=9', '4+5=9', '5+4=9', '6+3=9', '7+2=9', '8+1=9', '9+0=9']
# print('-----------第2步 单元格制作-----------')
# 屋顶总数的坐标,无论左列空还是右列空,都是0100,0102,0104
bgb1=[]
for l1 in range(1,2): # 行
for y1 in range(0,14,2): # 列
s1='{}{}'.format('%02d'%l1,'%02d'%y1) # 数字加空格
bgb1.append(s1)
print(bgb1)
# ['0100', '0102', '0104', '0106', '0108', '0110', '0112']
print(len(bgb1))
# 7
if zyk==2: # 右列空
# 左侧数字的坐标(30、40)写在一起,
bgb2=[]
for y2 in range(0,14,2): # 列 左是0,14,2 / 右是1,14,2
for l2 in range(3,13): # 行 连续行
s2='{}{}'.format('%02d'%l2,'%02d'%y2) # 数字加空格
bgb2.append(s2)
print(bgb2)
# ['0003', '0004', '0005', '0006', '0007', '0008', '0009', '0010', '0011', '0012', '0203', '0204', '0205', '0206', '0207', '0208', '0209', '0210', '0211', '0212', '0403', '0404', '0405', '0406', '0407', '0408', '0409', '0410', '0411', '0412', '0603', '0604', '0605', '0606', '0607', '0608', '0609', '0610', '0611', '0612', '0803', '0804', '0805', '0806', '0807', '0808', '0809', '0810', '0811', '0812', '1003', '1004', '1005', '1006', '1007', '1008', '1009', '1010', '1011', '1012', '1203', '1204', '1205', '1206', '1207', '1208', '1209', '1210', '1211', '1212']
print(len(bgb2))
# 70
if zyk==1:# 左列空
bgb2=[]
for y2 in range(1,14,2): # 列 左是0,14,2 / 右是1,14,2
for l2 in range(3,13): # 行 连续行
s2='{}{}'.format('%02d'%l2,'%02d'%y2) # 数字加空格
bgb2.append(s2)
print(bgb2)
# ['0003', '0004', '0005', '0006', '0007', '0008', '0009', '0010', '0011', '0012', '0203', '0204', '0205', '0206', '0207', '0208', '0209', '0210', '0211', '0212', '0403', '0404', '0405', '0406', '0407', '0408', '0409', '0410', '0411', '0412', '0603', '0604', '0605', '0606', '0607', '0608', '0609', '0610', '0611', '0612', '0803', '0804', '0805', '0806', '0807', '0808', '0809', '0810', '0811', '0812', '1003', '1004', '1005', '1006', '1007', '1008', '1009', '1010', '1011', '1012', '1203', '1204', '1205', '1206', '1207', '1208', '1209', '1210', '1211', '1212']
print(len(bgb2))
# 屋顶坐标+左侧列坐标合并=11个格子一组
bg=[]
u=int(len(bgb2)/(tm)) #u=10个 tm-7
for q in range(int(tm)): # q=0--7
aa=bgb2[q*u:q*u+u] # a提取前10个坐标
aa.insert(0,bgb1[q]) # a的十个坐标前面再加一个屋顶坐标 一共11个坐标
bg.append( aa)
# 添加成为[['11个坐标'],['11个坐标'],['11个坐标']]d的样式
print(bg)
print(len(bg))
# # [['0100', '0300', '0400', '0500', '0600', '0700', '0800', '0900', '1000', '1100', '1200'],
# # ['0102', '0302', '0402', '0502', '0602', '0702', '0802', '0902', '1002', '1102', '1202'],
# # ['0104', '0304', '0404', '0504', '0604', '0704', '0804', '0904', '1004', '1104', '1204'],
# # ['0106', '0306', '0406', '0506', '0606', '0706', '0806', '0906', '1006', '1106', '1206'],
# # ['0108', '0308', '0408', '0508', # '0608', '0708', '0808', '0908', '1008', '1108', '1208'],
# # ['0110', '0310', '0410', '0510', '0610', '0710', '0810', '0910', '1010', '1110', '1210'],
# # ['0112', '0312', '0412', '0512', '0612', '0712', '0812', '0912', '1012', '1112', '1212']]
# 新建一个”装N份word和PDF“的临时文件夹
imagePath1=r'C:\Users\jg2yXRZ\OneDrive\桌面\分合题\零时Word'
if not os.path.exists(imagePath1): # 判断存放图片的文件夹是否存在
os.makedirs(imagePath1) # 若图片文件夹不存在就创建
print('-----------第3步 随机抽取题目,考虑格子的数量,确认坐标重新提取格子-----------')
# D=[]
# n=int(num/2)
for z in range(0,int(num/2)): #多少份
# 新建word
doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\分合题\04分合-分-下-房屋.docx')
# .clear()
for j in range(2):
table = doc.tables[j] # 表0,表2 写标题用的
# D=[]
# 小于9的题目,要计算一共有几题,写入等量的单元格内,
# for xx in A :
# D.append(xx)
# # # 第一行的班级和项目
if zyk==2: # 右列空
title='{}-{}抽取{}题 房屋右空 升序'.format(sum1,sum2,tm)
if zyk==1: # 左列空
title='{}-{}抽取{}题 房屋左空 升序'.format(sum1,sum2,tm)
d='0004'
C=random.sample(LIST,tm)
print('随机抽取[[],[]]----{}'.format(C))
# 随机抽了9、3、7、8、2、6、1 一共7个数字的所有题目)
# [['0+9=9', '1+8=9', '2+7=9', '3+6=9', '4+5=9', '5+4=9', '6+3=9', '7+2=9', '8+1=9', '9+0=9'],
# ['0+3=3', '1+2=3', '2+1=3', '3+0=3'],
# ['0+7=7', '1+6=7', '2+5=7', '3+4=7', '4+3=7', '5+2=7', '6+1=7', '7+0=7'],
# ['0+8=8', '1+7=8', '2+6=8', '3+5=8', '4+4=8', '5+3=8', '6+2=8', '7+1=8', '8+0=8'],
# ['0+2=2', '1+1=2', '2+0=2'],
# ['0+6=6', '1+5=6', '2+4=6', '3+3=6', '4+2=6', '5+1=6', '6+0=6'],
# ['0+1=1', '1+0=1']]
# 提取7题每题里面屋顶总数
sl=[]
for e in range(int(len(C))):
f=int(len(C[e])) # 提取7题每题里面屋顶总数 如果体量是5题,数字就是4
sl.append(f)
print('提取7题每题里面数量{}'.format(sl))
# 7题,每一题里面包含的数量 做少1题=0,最多10题=9
# [10, 4, 7, 8, 9, 3, 1]
# 提取随机抽数后的每题的等量坐标格子
bgall=[]
# 提取等量的坐标
# 屋顶数量=数量-1
for s in range(len(sl)): # 7个
for h in bg[s][:int(sl[s]+1)]:
bgall.append(h) # 添加全部坐标列表bg的第一组列表里面所有题目的0-X个坐标,因为包含了屋顶坐标,所以坐标组还要加1
bgall.insert(0,d) # 在0第一个位置插入标题的坐标
print('提取坐标总量{}'.format(bgall))
print(len(bgall))
# 提取要输入格子的题目数字 一个总数 X个01234
K=[]
# 屋顶数量=数量-1
for u in range(len(sl)): # 7个
# u.append(int(sl-1)) # 屋顶写入的数字
K.append(str(sl[u]-1)) # 写入屋顶总数,需要减去1
for g in C[u]: # 单个元素添加
K.append(g) # 添加全部题目列表C的第一组列表里面所有题目的0的数字(这里都是1位数,所以提取0)
K.insert(0,title) # 在0第一个位置插入标题的文字
print(K)
print(len(K))
# 标题写入3、5单元格
for t in range(0,len(bgall)): # 0-5是最下面一行,用来写卡片数字
pp=int(bgall[t][0:2]) #
qq=int(bgall[t][2:4])
k=K[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(25) #是否加粗
# run.font.color.rgb = RGBColor(150,150,150) #数字小,颜色深0-255
run.font.color.rgb = RGBColor(100,100,100) #数字小,颜色深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.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)
if zyk==2:# 右列空
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/分合题/(打印合集)01“+”(一页两份 ){}-{}之间分合屋顶抽{}题 右空({}人打印{}张).pdf" .format('%02d'%sum1,'%02d'%sum2,tm,num,int(num/2)))
if zyk==1:# 左列空
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/分合题/(打印合集)01“+”(一页两份 ){}-{}之间分合屋顶抽{}题 左空({}人打印{}张).pdf" .format('%02d'%sum1,'%02d'%sum2,tm,num,int(num/2)))
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/分合题/零时Word') #递归删除文件夹,即:删除非空文件夹