背景需求:
根据需求,0-5以内的判断是21题正确,21题错误,但由于错误答案是随机数抽取,有可能恰好是正确的,所以会出现每套题目的正确数和错误数不一样的情况
优化思路一:
设置如果错误答案与正确答案数字相同,再次抽取一下
'''用随机方式生成加法错误答案。会出现正确答案,如何解决?
作者:阿夏
时间:2023年12月24日 19:17'''
import random
sum1=0
sum2=5
for y in range(10):
P1=[]# 正确
for a in range(0,sum2+1): # 起始数字就是10,就是排除掉0-10之间的数字
for b in range(0,sum2+1): # 起始数字为0,
if 0<=a+b<sum2+1:
w=random.randint(sum1,sum2) # 随机生成错误数字
# print('{}+{}='.format(a,b))
P1.append('{}+{}={}'.format('%02d'%a,'%02d'%b,'%02d'%(a+b)))
if 0<=b+a<sum2+1:
# print('{}+{}='.format(a,b))
P1.append('{}+{}={}'.format('%02d'%b,'%02d'%a,'%02d'%(a+b)))
else:
pass
P1 =list(set(P1)) # 排除重复,但随机打乱
P1.sort() # 小到大排序
# print(P1)
# 正确的答案
P2=[]# 不正确的答案随机抽取
for p in P1:
# while True:
w=random.randint(0,10) # 随机生成错误数字
v='%02d'%w # 错误数字变成两位数
if v!=p[6:]: # 如果错误数字不等于答案数字,写入
P2.append(p[0:6]+'{}'.format('%02d'%(w)))
continue
else: # 如果错误数字等于答案数字,,再次抽取
w=random.randint(sum1,sum2) # 随机生成错误数字
# # 如果错误数字等于正确答案,就把这个错误数字加1,避开正确答案
P2.append(p[0:6]+'{}'.format('%02d'%(w)))
# print(P2)
P=P1+P2
# print(P)
P =list(set(P)) # 排除重复,但随机打乱
P.sort() # 小到大排序
# print(P)
print('第{}次数量{}'.format(y,len(P)))
结果:
虽然误差率减少,但是不排除第二次再次抽取随机数字,也是恰好是正确答案。
为了赶时间,所以先用优化1的代码打印了作业10张0-5 20张0-10
优化思路二:
while 循环,如果抽取的错误答案数字与正确答案相同,就再次循环抽取,直到抽出的数字不相等。
'''用随机方式生成加法错误答案。会出现正确答案,如何解决?
while break continue
作者:阿夏
时间:2023年12月24日 19:17'''
import random
sum1=0
sum2=10
for y in range(10):
P1=[]# 正确
for a in range(0,sum2+1): # 起始数字就是10,就是排除掉0-10之间的数字
for b in range(0,sum2+1): # 起始数字为0,
if 0<=a+b<sum2+1:
w=random.randint(sum1,sum2) # 随机生成错误数字
# print('{}+{}='.format(a,b))
P1.append('{}+{}={}'.format('%02d'%a,'%02d'%b,'%02d'%(a+b)))
if 0<=b+a<sum2+1:
# print('{}+{}='.format(a,b))
P1.append('{}+{}={}'.format('%02d'%b,'%02d'%a,'%02d'%(a+b)))
else:
pass
P1 =list(set(P1)) # 排除重复,但随机打乱
P1.sort() # 小到大排序
# print(P1)
# 正确的答案
P2=[]# 不正确的答案随机抽取
for p in P1:
while True:
w=random.randint(0,10) # 随机生成错误数字
v='%02d'%w # 错误数字变成两位数
if v!=p[6:]: # 如果错误数字不等于答案数字,写入
P2.append(p[0:6]+'{}'.format('%02d'%(w)))
break # 跳出循环
if v==p[6:]: # 如果错误数字等于答案数字,继续生成
continue # 继续循环 把这道题再次随机抽一次答案
# print(P2)
P=P1+P2
# print(P)
P =list(set(P)) # 排除重复,但随机打乱
P.sort() # 小到大排序
# print(P)
print('第{}次数量{}'.format(y,len(P)))
结果:
实现了“21正确题+21题错误题” 没有重复的结果
最终结果:
代码展示——正序(检查题量正确)
'''
正序版(目的:检查题量正确)
X-Y 之间的所有加法题的判断题3.0(随机生成绝对错误答案while break continue,考虑正确和不正确题的比例,如正确数量20%,错误数量80%),
时间:2023年12月25日 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('打印几份(必须双数,根据人数,如32人)\n'))
classroom=input('班级(输入中、大)\n')
bl=int(input('正确题的比例,如2,就是20%的正确题,80%的错误题\n'))
size=20
height1=11
weight1=4
gz=height1*weight1 # 115
sum1=int(input('X-Y以内的“+” 最小数字X(0)\n'))
sum2=int(input('X-Y以内的“+” 最大数字Y(0-99)\n'))
# 5以内“+”题共21题
P1=[]# 正确
for a in range(0,sum2+1): # 起始数字就是10,就是排除掉0-10之间的数字
for b in range(0,sum2+1): # 起始数字为0,
if 0<=a+b<sum2+1:
w=random.randint(sum1,sum2) # 随机生成错误数字
# print('{}+{}='.format(a,b))
P1.append('{}+{}={}'.format('%02d'%a,'%02d'%b,'%02d'%(a+b)))
if 0<=b+a<sum2+1:
# print('{}+{}='.format(a,b))
P1.append('{}+{}={}'.format('%02d'%b,'%02d'%a,'%02d'%(a+b)))
else:
pass
P1 =list(set(P1)) # 排除重复,但随机打乱
P1.sort() # 小到大排序
print(P1)
# 正确的答案
# ['00+00=00', '00+01=01', '00+02=02', '00+03=03', '00+04=04', '00+05=05', '01+00=01', '01+01=02', '01+02=03', '01+03=04', '01+04=05', '02+00=02', '02+01=03', '02+02=04', '02+03=05', '03+00=03', '03+01=04', '03+02=05', '04+00=04', '04+01=05', '05+00=05']
# 新建一个”装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\桌面\加减法\04判断模板一页两份.docx')
for j in range(2):
P2=[]# 不正确的答案随机抽取
for p in P1:
while True:
w=random.randint(sum1,sum2) # 随机生成错误数字
v='%02d'%w # 错误数字变成两位数
if v!=p[6:]: # 如果错误数字不等于答案数字,写入
P2.append(p[0:6]+'{}'.format('%02d'%(w)))
break
else: # 如果错误数字等于答案数字,,再次抽取
continue
print(P2)
# ['00+00=10', '00+01=10', '00+02=10', '00+03=10', '00+04=10', '00+05=10', '01+00=10', '01+01=10', '01+02=10', '01+03=10', '01+04=10', '02+00=10', '02+01=10', '02+02=10', '02+03=10', '03+00=10', '03+01=10', '03+02=10', '04+00=10', '04+01=10', '05+00=10']
P3=P1+P2
# [[],[]]
print('P3长度{}'.format(len(P3)))
# 二位数去0
P4=[]
for i in P3: # 每个内容是00+00=00,一共6个字符
# print(i)
if i[0]=='0'and i[3]=='0' and i[6]=='0':
P4.append(i[1:3]+i[4:6]+i[7])
if i[0]=='0'and i[3]=='0'and i[6]!='0':
P4.append(i[1:3]+i[4:])
if i[0]=='0'and i[3]!='0'and i[6]!='0':
P4.append(i[1:])
if i[0]=='0'and i[3]!='0'and i[6]=='0':
P4.append(i[1:6]+i[7])
if i[0]!='0'and i[3]=='0'and i[6]=='0':
P4.append(i[0:3]+i[4:6]+i[7])
if i[0]!='0'and i[3]!='0'and i[6]=='0':
P4.append(i[0:6]+i[7])
if i[0]!='0'and i[3]=='0'and i[6]!='0':
P4.append(i[0:3]+i[4:])
if i[0]!='0'and i[3]!='0'and i[6]!='0':
P4.append(i)
print(P4)
print('{}-{}之间的加法判断题共有 {} 题'.format(sum1,sum2,len(P4)) ) # 42
# 如果正确题+错误题大于44题
P=[]
if len(P4)>gz:
# 正确题在前,错误题在后
P5=[]
f=int(len(P4)/2) # 21
for e in range(int(len(P4)/f)):
P5.append(P4[e*f:e*f+f])
print(P5)
# 随机抽取比例 共44题
zq=int(gz*(bl*10/100))
cw=gz-zq
# 从P5[0]随机抽取20%, 从P5[1]随机抽取80%,组成P
a1=P5[0]
a2=P5[1]
t1=random.sample (a1,zq)
t2=random.sample (a2,cw)
for t3 in t1:
P.append(t3)
for t4 in t2:
P.append(t4)
# random.shuffle(P) # 随机打乱
# 暂时不打乱
if len(P4)<=gz:
for t5 in P4:
P.append(t5)
# random.shuffle(P) # 随机打乱
print(P)
print('{}-{}之间的加法判断共有 {} 题'.format(sum1,sum2,len(P)) ) # 42
# 第一行的班级和项目
A=[]
c='{}'.format(classroom)
if len(P1) <=gz:
title='{}-{}“+”✓×{}抽{}题5:5'.format(sum1,sum2,len(P1),len(P),bl,10-bl)
if len(P1) >gz:
title='{}-{}“+”✓×{}抽{}题{}:{}'.format(sum1,sum2,len(P1),gz,bl,10-bl)
d=['0003','0006']
# 表格0 表格2的 03 05单元格里写入标题信息c
A.append(c)
A.append(title)
print(A)
# 制作"单元格"
bg=[]
for x in range(0,weight1*3,3): # 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))
# 如果题目总数小于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('') # 预留一个空行做分割线
v=random.sample(P,len(P)) # 从21题随机抽取不重复21
for u in v: # 遍历提取
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
time.sleep(1)
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/桌面/加减法/(打印合集)05(一页两份 ){}题{}-{}加法判断题✓×打乱“+”共{}题抽{}题{}比{}({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P1),'%02d'%len(P), bl,int(10-bl),c,num,num))
else:
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)05(一页两份 ){}题{}-{}加法判断题✓×打乱“+”共{}题抽{}题{}比{}({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P1),gz, bl,int(10-bl),c,num,num))
#
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word') #递归删除文件夹,即:删除非空文件夹
测试结果——正序(检查题量正确)
代码展示——乱序
'''
正序版(目的:检查题量正确)
X-Y 之间的所有加法题的判断题3.0(随机生成绝对错误答案while break continue,考虑正确和不正确题的比例,如正确数量20%,错误数量80%),
时间:2023年12月25日 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('打印几份(必须双数,根据人数,如32人)\n'))
classroom=input('班级(输入中、大)\n')
bl=int(input('正确题的比例,如2,就是20%的正确题,80%的错误题\n'))
size=20
height1=11
weight1=4
gz=height1*weight1 # 115
sum1=int(input('X-Y以内的“+” 最小数字X(0)\n'))
sum2=int(input('X-Y以内的“+” 最大数字Y(0-99)\n'))
# 5以内“+”题共21题
P1=[]# 正确
for a in range(0,sum2+1): # 起始数字就是10,就是排除掉0-10之间的数字
for b in range(0,sum2+1): # 起始数字为0,
if 0<=a+b<sum2+1:
w=random.randint(sum1,sum2) # 随机生成错误数字
# print('{}+{}='.format(a,b))
P1.append('{}+{}={}'.format('%02d'%a,'%02d'%b,'%02d'%(a+b)))
if 0<=b+a<sum2+1:
# print('{}+{}='.format(a,b))
P1.append('{}+{}={}'.format('%02d'%b,'%02d'%a,'%02d'%(a+b)))
else:
pass
P1 =list(set(P1)) # 排除重复,但随机打乱
P1.sort() # 小到大排序
print(P1)
# 正确的答案
# ['00+00=00', '00+01=01', '00+02=02', '00+03=03', '00+04=04', '00+05=05', '01+00=01', '01+01=02', '01+02=03', '01+03=04', '01+04=05', '02+00=02', '02+01=03', '02+02=04', '02+03=05', '03+00=03', '03+01=04', '03+02=05', '04+00=04', '04+01=05', '05+00=05']
# 新建一个”装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\桌面\加减法\04判断模板一页两份.docx')
for j in range(2):
P2=[]# 不正确的答案随机抽取
for p in P1:
while True:
w=random.randint(sum1,sum2) # 随机生成错误数字
v='%02d'%w # 错误数字变成两位数
if v!=p[6:]: # 如果错误数字不等于答案数字,写入
P2.append(p[0:6]+'{}'.format('%02d'%(w)))
break
else: # 如果错误数字等于答案数字,,再次抽取
continue
print(P2)
# ['00+00=10', '00+01=10', '00+02=10', '00+03=10', '00+04=10', '00+05=10', '01+00=10', '01+01=10', '01+02=10', '01+03=10', '01+04=10', '02+00=10', '02+01=10', '02+02=10', '02+03=10', '03+00=10', '03+01=10', '03+02=10', '04+00=10', '04+01=10', '05+00=10']
P3=P1+P2
# [[],[]]
print('P3长度{}'.format(len(P3)))
# 二位数去0
P4=[]
for i in P3: # 每个内容是00+00=00,一共6个字符
# print(i)
if i[0]=='0'and i[3]=='0' and i[6]=='0':
P4.append(i[1:3]+i[4:6]+i[7])
if i[0]=='0'and i[3]=='0'and i[6]!='0':
P4.append(i[1:3]+i[4:])
if i[0]=='0'and i[3]!='0'and i[6]!='0':
P4.append(i[1:])
if i[0]=='0'and i[3]!='0'and i[6]=='0':
P4.append(i[1:6]+i[7])
if i[0]!='0'and i[3]=='0'and i[6]=='0':
P4.append(i[0:3]+i[4:6]+i[7])
if i[0]!='0'and i[3]!='0'and i[6]=='0':
P4.append(i[0:6]+i[7])
if i[0]!='0'and i[3]=='0'and i[6]!='0':
P4.append(i[0:3]+i[4:])
if i[0]!='0'and i[3]!='0'and i[6]!='0':
P4.append(i)
print(P4)
print('{}-{}之间的加法判断题共有 {} 题'.format(sum1,sum2,len(P4)) ) # 42
# 如果正确题+错误题大于44题
P=[]
if len(P4)>gz:
# 正确题在前,错误题在后
P5=[]
f=int(len(P4)/2) # 21
for e in range(int(len(P4)/f)):
P5.append(P4[e*f:e*f+f])
print(P5)
# 随机抽取比例 共44题
zq=int(gz*(bl*10/100))
cw=gz-zq
# 从P5[0]随机抽取20%, 从P5[1]随机抽取80%,组成P
a1=P5[0]
a2=P5[1]
t1=random.sample (a1,zq)
t2=random.sample (a2,cw)
for t3 in t1:
P.append(t3)
for t4 in t2:
P.append(t4)
random.shuffle(P) # 随机打乱
# 暂时不打乱
if len(P4)<=gz:
for t5 in P4:
P.append(t5)
random.shuffle(P) # 随机打乱
print(P)
print('{}-{}之间的加法判断共有 {} 题'.format(sum1,sum2,len(P)) ) # 42
# 第一行的班级和项目
A=[]
c='{}'.format(classroom)
if len(P1) <=gz:
title='{}-{}“+”✓×{}抽{}题5:5'.format(sum1,sum2,len(P1),len(P),bl,10-bl)
if len(P1) >gz:
title='{}-{}“+”✓×{}抽{}题{}:{}'.format(sum1,sum2,len(P1),gz,bl,10-bl)
d=['0003','0006']
# 表格0 表格2的 03 05单元格里写入标题信息c
A.append(c)
A.append(title)
print(A)
# 制作"单元格"
bg=[]
for x in range(0,weight1*3,3): # 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))
# 如果题目总数小于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('') # 预留一个空行做分割线
v=random.sample(P,len(P)) # 从21题随机抽取不重复21
for u in v: # 遍历提取
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
time.sleep(1)
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/桌面/加减法/(打印合集)05(一页两份 ){}题{}-{}加法判断题✓×打乱“+”共{}题抽{}题{}比{}({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P1),'%02d'%len(P), bl,int(10-bl),c,num,num))
else:
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)05(一页两份 ){}题{}-{}加法判断题✓×打乱“+”共{}题抽{}题{}比{}({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P1),gz, bl,int(10-bl),c,num,num))
#
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word') #递归删除文件夹,即:删除非空文件夹
结果展示——乱序
21:21
同样测试0-10之间加法 2:8比例 =8题正确36题错误。
结论:
这样抽取的数量就不会有误差了。(* ̄︶ ̄)
教学过程:
时间:2023年12月26日 9:00-9:30
班级:大四班
人数:28人
材料准备:(是优化1的代码,出现正确题与错误题比例有些许误差)
通过幼儿作业验证比例数量正确性
加上下面2个,正好21题正确
以下这套题目2:8,应该是8个正确,44个错误,数出来有9题正确,其中有一题应该是错误题,但答案正好是正确答案。
0-5 5:5题目正确21题,错误21题,可以验证到底哪一题出现2次正确,图中可见1+2=3出现了2次,实际上应该1+2=3,和1+2=0这两种题目样式。
0-5 5:5题目正确21题,错误21题,可以验证到底哪一题出现2次正确,图中可见2+2=4出现了2次,实际上应该2+2=4,和2+2=1这两种题目样式。
有错误的答题方式(因为题目有难度,所以不纠正)
1、幼儿将第2个被加数与合计数相加
结论:
1.精确代码,确保正确数量比例
通过代码1的测试,已经大大降低了错误题随机答案正好等于正确答案的几率,但是误差存在,所以要控制题目数量比例,还是必须用while循环,确保反复抽取非正确的答案数。
案例:今天,有1位女孩和一位男孩询问自己的正确率,我告知他们正确题目数量,他们数了一下,很巧,她们拿到的题目正好是0-5 21题正确。0-10 8题正确,没有验证失败。
2.判断题有难度,
幼儿做题要非常小心,才能判断错误。2/3幼儿可以模仿书写√×,
不会做的孩子问同伴,会做的的孩子抱怨:“他们老是来问我!烦死了”
3.新题型——数独
有一位男孩说:这里面都是错题。
我说:是的,0-10里面只有8题正确,其他都是错误,
他说:这个对错题目太简单了,我家里都做“数独”了!