【教学类-42-03】20231225 X-Y 之间加法题判断题3.0(确保错误题有绝对错误的答案)

news2024/11/21 0:39:48

背景需求:

根据需求,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题正确,其他都是错误,

他说:这个对错题目太简单了,我家里都做“数独”了!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1337587.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

TypeScript学习(基础篇)

前言 在现代的Web开发生态系统中&#xff0c;JavaScript已经成为一种必备的技术。然而&#xff0c;随着应用的增大&#xff0c;JavaScript的一些限制开始显现&#xff0c;例如缺乏静态类型检查和编译时错误检查。这正是TypeScript发挥作用的地方&#xff0c;TypeScript是一种静…

软件测试自学还是报班好?

如果你学软件测试&#xff0c;是以就业为目的&#xff0c;而且是以高薪就业为目的&#xff0c;那我们就要去反推&#xff0c;为了这个目标&#xff0c;我们要去做什么事情。 为了“将高薪就业为目的&#xff0c;我们要做什么事情”阐述清楚&#xff0c;本文行文结构如下&#x…

接口测试及常用接口测试工具(postman/jmeter)附教程

首先&#xff0c;什么是接口呢&#xff1f; 接口一般来说有两种&#xff0c;一种是程序内部的接口&#xff0c;一种是系统对外的接口。 系统对外的接口&#xff1a;比如你要从别的网站或服务器上获取资源或信息&#xff0c;别人肯定不会把数据库共享给你&#xff0c;他只能给…

Netty—Reactor线程模型详解

文章目录 前言线程模型基本介绍线程模型分类Reactor线程模型介绍Netty线程模型&#xff1a; 传统阻塞IO的缺点Reactor线程模型单Reactor单线程模式单Reactor多线程模式主从Reactor多线程Reactor 模式小结 Netty 线程模型案例说明&#xff1a;Netty核心组件简介ChannelPipeline与…

条件覆盖和条件组合覆盖测试设计-实验八例题

目录 条件覆盖 判定-条件覆盖 条件组合覆盖 实验内容&#xff1a; 以银行内部转账为实例&#xff0c;针对内部转账业务逻辑代码进行分析&#xff0c;运用条件覆盖和条件组合覆盖进行测试用例设计。 实验过程&#xff1a; 条件覆盖 条件覆盖&#xff08;Condition Cover…

官宣定了!2024年举办4次PMP认证考试,每个季度一次

就在刚刚&#xff0c;2023年12月26日14:05分&#xff0c;PMI和中国国际人才交流基金会通过官微&#xff0c;联合发布了2024年PMI认证考试计划的通知&#xff0c;正式宣告了2024年的PMP考试初步安排。 这个通知发布之后&#xff0c;有一些伙伴问华研荟一些细节问题&#xff0c;…

挑战Python100题(6)

100+ Python challenging programming exercises 6 Question 51 Define a class named American and its subclass NewYorker. Hints: Use class Subclass(ParentClass) to define a subclass. 定义一个名为American的类及其子类NewYorker。 提示:使用class Subclass(Paren…

vue-awesome-swiper轮播组件

安装版本&#xff1a;"swiper": "^6.0.0", 安装版本&#xff1a;"vue-awesome-swiper": "^4.1.1", <div class"swiper_conter"><swiper class"swiper" :options"swiperOption" ref"mySw…

怎么实现Servlet的自动加载

在实际开发时&#xff0c;有时候会希望某些Servlet程序可以在Tomcat启动时随即启动。但在默认情况下&#xff0c;第一次访问servlet的时候&#xff0c;才创建servlet对象。 如果servlet构造函数里面的代码或者init方法里面的代码比较多&#xff0c;就会导致用户第一次访问serv…

浅谈能效管理平台在污水处理厂中的应用

摘要&#xff1a;《“十四五”城镇污水处理及资源化利用发展规划》指出&#xff0c;2021—2025 年合理减缓我国城镇污水收集处理设施发展不平衡不充分的矛盾&#xff0c;系统推动补短板强弱项&#xff0c;全方面提升污水收集处理效能&#xff0c;加速推进污水资源化利用&#x…

溴乙腈,2028年将以4.5%左右的复合年增长率增长

溴乙腈是一种化合物&#xff0c;主要用作合成各种药物、农用化学品和其他特种化学品的中间体。近年来&#xff0c;受医疗保健、农业和化学制造等各种最终用途行业对溴乙腈的需求不断增加的推动&#xff0c;全球溴乙腈市场一直在稳步增长。全球市场分析&#xff1a; 在制药和农业…

【Unity地形】使用地形工具创建场景环境-Terrain

如上图Unity的地形工具可以让我们实现创建复杂、丰富的3D室外环境。 我们创建地形很简单&#xff0c;在层级面板中右键-3Dobject-Terrain 就可以创建一个默认的地形模型&#xff01;这个模型是Unity内置的。 接下来的地形编辑功能全部集中在这个地形的组件上 主要功能如下&…

怎么修复MSVCR110.dll文件?全面解析MSVCR110.dll缺失修复方法

MSVCR110.dll文件缺失问题在Windows操作系统用户中相当普遍&#xff0c;经常导致应用程序启动失败或崩溃。MSVCR110.dll是Microsoft Visual C Redistributable for Visual Studio 2012的一部分&#xff0c;且应用程序通常依赖这个DLL文件来执行C库中的代码。文件的丢失可能源自…

Rabbit加密算法

一、引言 随着信息技术的快速发展&#xff0c;数据安全已成为越来越受到重视的领域。加密算法作为保障数据安全的重要技术手段&#xff0c;在通信、存储等领域得到了广泛应用。Rabbit加密算法作为一种新型的加密算法&#xff0c;凭借其简单易懂的原理、高速的运算性能以及良好…

isEmpty 和 isBlank 的用法区别,居然一半的人答不上来.....

亲爱的小伙伴们&#xff0c;由于微信公众号改版&#xff0c;打乱了发布时间&#xff0c;为了保证大家可以及时收到文章的推送&#xff0c;可以点击上方蓝字关注测试工程师成长之路&#xff0c;并设为星标就可以第一时间收到推送哦&#xff01; 也许你两个都不知道,也许你除了is…

MuJava提供的方法级别的7类变异算子总结

MuJava简洁 Java (muJava) 是 Java 程序的变异系统。 它自动生成用于传统突变测试和类级别突变测试的突变体。 Java 可以测试单个类和多个类的包。 用户以对封装在单独 JUnit 类的方法中的被测类的方法调用序列的形式提供测试。 官网地址&#xff1a;Java Home Page 归档表格…

【Mybatis】深入学习MyBatis:概述、主要特性以及配置与映射

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a; Mybatis ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 一、概述 MyBatis简介 主要特性 1. 动态SQL 2.结果映射 3 .插件机制 二、MyBatis配置文件 1.配置文件结构 数据库连…

力扣-收集足够苹果的最小花园周长[思维+组合数]

题目链接 题意&#xff1a; 给你一个用无限二维网格表示的花园&#xff0c;每一个 整数坐标处都有一棵苹果树。整数坐标 (i, j) 处的苹果树有 |i| |j| 个苹果。 你将会买下正中心坐标是 (0, 0) 的一块 正方形土地 &#xff0c;且每条边都与两条坐标轴之一平行。 给你一个整…

labelme目标检测数据类型转换

1. labelme数据类型 LabelMe是一个开源的在线图像标注工具&#xff0c;旨在帮助用户创建和标记图像数据集。它提供了一个用户友好的界面&#xff0c;让用户可以直观地在图像上绘制标记框、多边形、线条等&#xff0c;以标识和注释图像中的对象或区域。 GitHub&#xff1a;http…

[linux]高级IO

文章目录 高级IO0. IO介绍1. 五种IO模型1.0 感性理解(故事版)1.1 阻塞IO1.2 非阻塞IO1.3 信号驱动IO1.4 IO多路转接1.5 异步IO 2. 高级IO重要概念2.1 同步通信 vs 异步通信2.2 阻塞 vs 非阻塞 3. 其他高级IO4. 非阻塞IO4.1 fcntl4.2 实现函数SetNoBlock4.2.0 阻塞方式读取标准输…