【教学类-06-15】20231213 (按比例抽题+乱序or先加后减)X-Y之间“加法减法+-题”

作品展示:

背景需求

1、加减混合题——加法题多,减法题少

大三班一位女孩让我给他批改0-10加减法混合题,我随机从每列题目里面选了2个加法和2个减法题抽查答案正确性。

“3+4=7,对,这里8+1=9 对”

然后我停顿几秒,才从一堆加法里,看到很少的几道减法题。

“10-2=8……6=2=4”,对了,你放书包吧!“

“老师给我打个√,写100分”女孩提出要求。

“好吧”,我找不到红笔,就用记号笔打钩,写了100分,还加了一个日期。

2、减法在哪里?——好像看不到减法

大四班的女孩在选题目纸,“这里好像都是加法的,没有减法的!“

“对,今天我没有打印全部减法的,不过有加减混合的题目!“

我给她拿了一份10-20加减法,

她看了半天:“好像没有减法啊”

我指着右上角的项目名称说“这里有加法和减法的符号+-,就是加减混合。”

“哦,我看到了这里有一道减法。减法真少哦!”

我一看,的确,第一列连着5题都是加法。

3、难不倒的高手——我要“加减乘”混合题

大三班的“第一高手”对我提供的每一套的题目都只有一种反应:

“这个是分合题,太简单了”

“乘法,乘法我也会,11的1 22的4 33的9,,44十六……”

“都太简单了,我不想做。”

……

老师感叹:“你太聪明了,这些题目都不适合你!”

他骄傲地回答,“不是我太聪明,是你的题目太简单了!”

o(╥﹏╥)o”

我们讨论了一下题目难度,最后他说:“我还不会除法,但是我会“加减乘””

“那专门给你一份‘加减乘’混合题,行吗?”

“好的!你下次来给我哦”

想到“加、减、×”,我感觉三种题型的话,是不是要控制一下出题数量的比例,比如他非常熟悉的加法减法少一点,让乘法多一点。让做题时间延长一点。

小结:
从教师自我观察和幼儿的反馈中,我感觉有必要对X-Y之间的“加减乘除”混合题,做一个出题比例上的控制

比如100道加减法题,可以是50道加法、50道减法。

WORD模板

Word模板的设计在这里面

【教学类-06-06】20231118 (55格版)0-X以内加法、减法、加减混合题(以0-5,0-10,0-15,0-20为例)(摸底测试)-CSDN博客文章浏览阅读91次。【教学类-06-06】20231118 (55格版)0-X以内加法、减法、加减混合题(以0-5,0-10,0-15,0-20为例)(摸底测试)https://blog.csdn.net/reasonsummer/article/details/134487509

1.0代码展示——“先加后减”样式

'''
X-Y 之间的所有加减混合法题(如10-20之间的所有加法+减法,10+0,10+1,10-0)
1、按比例抽题:0-10加减法,132题,55格抽取,27个加法 20个减法
2、考虑“乱序(加法减法混合)和先加后减 ”两种排列方法


时间:2023年12月13日 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'))

# int(input('一共几个单元格(55个)\n'))
classroom=input('班级(输入中、大)\n')
bl=int(input('加法题抽取(输2。就是2:8分,加法抽取20%,减法抽取80%)\n'))
size=20
height1=12
weight1=5
gz=(height1-1)*5
sum1=int(input('X-Y以内的“+-” 最小数字X\n'))
sum2=int(input('X-Y以内的“+-” 最大数字Y\n'))
l=int(input('输入1,加减法题目打乱,输入2,先出加法,再出减法\n'))


# for  sum in [sum2]:
# 5以内“+-”题共21题

P=[]
jia=[]
# 加法
for a in range(0,sum2+1):     # 起始数字就是10,就是排除掉0-10之间的数字
    for b in range(0,sum2+1):      # 起始数字为0,
        if sum1<=a+b<sum2+1:         
            # print('{}+{}='.format(a,b))
            jia.append('{}+{}='.format(a,b))
        if sum1<=b+a<sum2+1:         
            # print('{}+{}='.format(a,b))
            jia.append('{}+{}='.format(a,b))
        else:
            pass
# jia=list(set(jia))  # 加法题 去重 42变成21题
jia.sort() # 升序
print(jia)
print(len(jia))

# 减法
jian=[]
for a in range(sum2+1):
    for b in range(sum2+1):
        if sum1<=a-b<sum2+1:              
            # print('{}+{}='.format(a,b))
            jian.append('{}-{}='.format(a,b))
        if sum1<=b-a<sum2+1:  
            jian.append('{}-{}='.format(b,a))         
jian=list(set(jian)) # 减法题 去重 42变成21题
jian.sort() # 升序
print(len(jian)) # 21

P=len(jian)+len(jia)
print(P)# 0-5加法减法题目总数42

L=jia+jian
print(L)
print(len(L))
['0+0=', '0+1=', '0+2=', '0+3=', '0+4=', '0+5=', '1+0=', '1+1=', '1+2=', '1+3=', '1+4=', '2+0=', '2+1=', '2+2=', '2+3=', '3+0=', '3+1=', '3+2=', '4+0=', '4+1=', '5+0=', '0-0=', '1-0=', '1-1=', '2-0=', '2-1=', '2-2=', '3-0=', '3-1=', '3-2=', '3-3=', '4-0=', '4-1=', '4-2=', '4-3=', '4-4=', '5-0=', '5-1=', '5-2=', '5-3=', '5-4=', '5-5=']





# # print(P)
# # print(len(P))
# P =list(set(P))    # 排除重复,但随机打乱
# P.sort()    # 小到大排序
# print(P)
#     # ['0+0=', '0+1=', '0+2=', '0+3=', '0+4=', '0+5=', '1+0=', '1+1=', '1+2=', '1+3=', '1+4=', '2+0=', '2+1=', '2+2=', '2+3=', '3+0=', '3+1=', '3+2=', '4+0=', '4+1=', '5+0=']
#     # “+-”题生成都是按小到大排列的,不需要sort排序
# print('{}-{}之间的加法减法题共有  {}  题'.format(sum1,sum2,len(P)) )   # 21

# # 分两组


# 第一行的班级和项目
A=[]
c='{}'.format(classroom)

if P>gz:     # 0-10等于132题,大于55,单元格数量55
    print('数学题总数大于55,实际题目数量{}'.format(gz))
    sl=P
    tl1=int(gz*bl*10/100)     # 加法题的题量是 21*50/100  可能是浮点数10.5,所以要用int=10
    print(tl1)
    tl2=gz-tl1
    print(tl2)
    title='{}-{}“+-”{}抽{}题{}:{}'.format(sum1,sum2,P,gz,bl,int(10-bl))

    
    

if P<=gz:    # 0-5等于42题,小于于55,单元格数量42
    print('数学题总数小于55,实际题目数量{}'.format(P))
    sl=P
    tl1=len(jia)    # 加法题的题量是 21*50/100  可能是浮点数10.5,所以要用int=11
    print(tl1)
    tl2=P-tl1
    print(tl2)
    title='{}-{}“+-”{}抽{}题5:5'.format(sum1,sum2,P,P)


d=['0001','0002']
# 表格0 表格2的 03 05单元格里写入标题信息c
A.append(c)
A.append(title)
print(A)    

# 制作"单元格"
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 P <=gz:
    bg=bgall[0:2+P]
    print(bg)
    print(len(bg))
else:
    bg=bgall[0:2+gz]
    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=[]
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):
        D.clear()

        if P <=gz:
        # D=[]
        # 小于9的题目,要计算一共有几题,写入等量的单元格内,            
            
            C1=random.sample(jia,tl1)  
            for cc1 in C1:
                D.append(cc1)
            C2=random.sample(jian,tl2)  
            for cc2 in C2:
                D.append(cc2)

            if l==1:
                random.shuffle(D)  
            #  如果=1,加减混合打乱
            if l==2:
             #  如果=2,先出加法,再出减法
               pass

            print(D)
            print(len(D))
            
            D.insert(0,title)           # 写入班级,项目名称
            D.insert(0,classroom) 

        else:
        # D=[]
        # 大于9的题目,只要抽取55题,多余的写不下,
                      
            C1=random.sample(jia,tl1)  
            for cc1 in C1:
                D.append(cc1)
            C2=random.sample(jian,tl2)  
            for cc2 in C2:
                D.append(cc2)  

            if l==1:
                random.shuffle(D)  
            #  如果=1,加减混合打乱
            if l==2:
             #  如果=2,先出加法,再出减法
               pass
           

            print(D)
            print(len(D))

            D.insert(0,title)           # 写入班级,项目名称
            D.insert(0,classroom) 

    
#       # 房间模板(第一个表格)要写入的门牌号列表 
        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.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 P <=gz :
    if l==1:        # 打乱
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“+-”(一页两份 ){}题{}-{}之间正逆“+-”数量{}比{}乱序(共{}题抽{}题)({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,bl,10-bl,'%03d'%P,'%02d'%P,c,num,n))
    else:         # 先加后减
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“+-”(一页两份 ){}题{}-{}之间正逆“+-”数量{}比{}先加后减(共{}题抽{}题)({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,bl,10-bl,'%03d'%P,'%02d'%P,c,num,n))
else:
    if l==1:        # # 打乱
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“+-”(一页两份 ){}题{}-{}之间正逆“+-”数量{}比{}乱序(共{}题抽{}题)({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,bl,10-bl,'%03d'%P,gz,c,num,n))
    else:    # 先加后减
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“+-”(一页两份 ){}题{}-{}之间正逆“+-”数量{}比{}先加后减(共{}题抽{}题)({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,bl,10-bl,'%03d'%P,gz,c,num,n))

file_merger.close()
# doc.Close()

# # print('----------第5步:删除临时文件夹------------')    
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word') #递归删除文件夹,即:删除非空文件夹





        
        

重点说明

按比例抽题目数量,代码相对有点繁琐

所有加法题写一个列表,所有减法题写一个列表

P就是数量计算的标准

考虑题目总数>55格,和<=55格 两种情况

终端演示:

测试一:0-5加法减法,比例5:5  (加法21题、减法21题)

测试二:0-5加法减法,比例2:8   (加法21题、减法21题)

测试三:0-10加法减法,比例5:5 (加法27题、减法28题)

抽取比例,只对题目总数>55的组合有效果

测试四:0-10加法减法,比例2:8 (加法11题、减法44题)

抽取比例,只对题目总数>55的组合有效果

感悟:

1、通过抽取比例题,可以控制加法减法的额数量。

2、为了一目了然知道数量的分布情况。1.0这套是“先加法后减法”的方式。

3、实际上最好再做一次打乱,让加法和减法混在一起。

优化代码2.0——乱序排列和先加后减

'''
X-Y 之间的所有加减混合法题(如10-20之间的所有加法+减法,10+0,10+1,10-0)
1、按比例抽题:0-10加减法,132题,55格抽取,27个加法 20个减法
2、考虑“乱序(加法减法混合)和先加后减 ”两种排列方法


时间:2023年12月13日 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'))

# int(input('一共几个单元格(55个)\n'))
classroom=input('班级(输入中、大)\n')
bl=int(input('加法题抽取(输2。就是2:8分,加法抽取20%,减法抽取80%)\n'))
size=20
height1=12
weight1=5
gz=(height1-1)*5
sum1=int(input('X-Y以内的“+-” 最小数字X\n'))
sum2=int(input('X-Y以内的“+-” 最大数字Y\n'))
l=int(input('输入1,加减法题目打乱,输入2,先出加法,再出减法\n'))


# for  sum in [sum2]:
# 5以内“+-”题共21题

P=[]
jia=[]
# 加法
for a in range(sum1,sum2+1):     # 起始数字就是10,就是排除掉0-10之间的数字
    for b in range(sum1,sum2+1):      # 起始数字为0,
        if sum1<=a+b<sum2+1:         
            # print('{}+{}='.format(a,b))
            jia.append('{}+{}='.format(a,b))
        if sum1<=b+a<sum2+1:         
            # print('{}+{}='.format(a,b))
            jia.append('{}+{}='.format(a,b))
        else:
            pass
jia=list(set(jia))  # 加法题 去重 42变成21题
jia.sort() # 升序
print(len(jia))

# 减法
jian=[]
for a in range(sum2+1):
    for b in range(sum2+1):
        if sum1<=a-b<sum2+1:              
            # print('{}+{}='.format(a,b))
            jian.append('{}-{}='.format(a,b))
        if sum1<=b-a<sum2+1:  
            jian.append('{}-{}='.format(b,a))         
jian=list(set(jian)) # 减法题 去重 42变成21题
jian.sort() # 升序
print(len(jian)) # 21

P=len(jian)+len(jia)
print(P)# 0-5加法减法题目总数42

L=jia+jian
print(L)
print(len(L))
# ['0+0=', '0+1=', '0+2=', '0+3=', '0+4=', '0+5=', '1+0=', '1+1=', '1+2=', '1+3=', '1+4=', '2+0=', '2+1=', '2+2=', '2+3=', '3+0=', '3+1=', '3+2=', '4+0=', '4+1=', '5+0=', '0-0=', '1-0=', '1-1=', '2-0=', '2-1=', '2-2=', '3-0=', '3-1=', '3-2=', '3-3=', '4-0=', '4-1=', '4-2=', '4-3=', '4-4=', '5-0=', '5-1=', '5-2=', '5-3=', '5-4=', '5-5=']





# # print(P)
# # print(len(P))
# P =list(set(P))    # 排除重复,但随机打乱
# P.sort()    # 小到大排序
# print(P)
#     # ['0+0=', '0+1=', '0+2=', '0+3=', '0+4=', '0+5=', '1+0=', '1+1=', '1+2=', '1+3=', '1+4=', '2+0=', '2+1=', '2+2=', '2+3=', '3+0=', '3+1=', '3+2=', '4+0=', '4+1=', '5+0=']
#     # “+-”题生成都是按小到大排列的,不需要sort排序
# print('{}-{}之间的加法减法题共有  {}  题'.format(sum1,sum2,len(P)) )   # 21

# # 分两组


# 第一行的班级和项目
A=[]
c='{}'.format(classroom)

if P>gz:     # 0-10等于132题,大于55,单元格数量55
    print('数学题总数大于55,实际题目数量{}'.format(gz))
    sl=P
    tl1=int(gz*bl*10/100)     # 加法题的题量是 21*50/100  可能是浮点数10.5,所以要用int=10
    print(tl1)
    tl2=gz-tl1
    print(tl2)
    title='{}-{}“+-”{}抽{}题{}:{}'.format(sum1,sum2,P,gz,bl,int(10-bl))

    
    

if P<=gz:    # 0-5等于42题,小于于55,单元格数量42
    print('数学题总数小于55,实际题目数量{}'.format(P))
    sl=P
    tl1=len(jia)    # 加法题的题量是 21*50/100  可能是浮点数10.5,所以要用int=11
    print(tl1)
    tl2=P-tl1
    print(tl2)
    title='{}-{}“+-”{}抽{}题5:5'.format(sum1,sum2,P,P)


d=['0001','0002']
# 表格0 表格2的 03 05单元格里写入标题信息c
A.append(c)
A.append(title)
print(A)    

# 制作"单元格"
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 P <=gz:
    bg=bgall[0:2+P]
    print(bg)
    print(len(bg))
else:
    bg=bgall[0:2+gz]
    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=[]
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):
        D.clear()

        if P <=gz:
        # D=[]
        # 小于9的题目,要计算一共有几题,写入等量的单元格内,            
            
            C1=random.sample(jia,tl1)  
            for cc1 in C1:
                D.append(cc1)
            C2=random.sample(jian,tl2)  
            for cc2 in C2:
                D.append(cc2)

            if l==1:
                random.shuffle(D)  
            #  如果=1,加减混合打乱
            if l==2:
             #  如果=2,先出加法,再出减法
               pass

            print(D)
            print(len(D))
            
            D.insert(0,title)           # 写入班级,项目名称
            D.insert(0,classroom) 

        else:
        # D=[]
        # 大于9的题目,只要抽取55题,多余的写不下,
                      
            C1=random.sample(jia,tl1)  
            for cc1 in C1:
                D.append(cc1)
            C2=random.sample(jian,tl2)  
            for cc2 in C2:
                D.append(cc2)  

            if l==1:
                random.shuffle(D)  
            #  如果=1,加减混合打乱
            if l==2:
             #  如果=2,先出加法,再出减法
               pass
           

            print(D)
            print(len(D))

            D.insert(0,title)           # 写入班级,项目名称
            D.insert(0,classroom) 

    
#       # 房间模板(第一个表格)要写入的门牌号列表 
        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.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 P <=gz :
    if l==1:        # 打乱
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“+-”(一页两份 ){}题{}-{}之间正逆“+-”数量{}比{}乱序(共{}题抽{}题)({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,bl,10-bl,'%03d'%P,'%02d'%P,c,num,n))
    else:         # 先加后减
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“+-”(一页两份 ){}题{}-{}之间正逆“+-”数量{}比{}先加后减(共{}题抽{}题)({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,bl,10-bl,'%03d'%P,'%02d'%P,c,num,n))
else:
    if l==1:        # # 打乱
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“+-”(一页两份 ){}题{}-{}之间正逆“+-”数量{}比{}乱序(共{}题抽{}题)({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,bl,10-bl,'%03d'%P,gz,c,num,n))
    else:    # 先加后减
        file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“+-”(一页两份 ){}题{}-{}之间正逆“+-”数量{}比{}先加后减(共{}题抽{}题)({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,bl,10-bl,'%03d'%P,gz,c,num,n))

file_merger.close()
# doc.Close()

# # print('----------第5步:删除临时文件夹------------')    
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word') #递归删除文件夹,即:删除非空文件夹





        
        

终端样式:

测试一:0-10加减法,132题,题量5:5 55(27+28)   乱序

测试二:0-10加减法,132题,题量2:8 55(11+44)   乱序

测试三:0-10加减法,132题,题量2:8 55(11+44)   先加后减

感悟:

能够控制数量,将有利于个性需求,生成有侧重点的加减乘除混合运算题。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

22.Java程序设计-基于SpringBoot的批发零售业商品管理小程序系统的设计与实现

摘要&#xff1a; 批发零售业商品管理小程序系统的设计旨在提高批发商、零售商和管理员的业务效率&#xff0c;实现商品的高效管理、订单的快速处理以及库存的精准监控。本系统基于Spring Boot框架&#xff0c;利用其强大的特性和生态系统&#xff0c;结合小程序前端&#xff…

R语言对医学中的自然语言(NLP)进行机器学习处理(1)

什么是自然语言(NLP)&#xff0c;就是网络中的一些书面文本。对于医疗方面&#xff0c;例如医疗记录、病人反馈、医生业绩评估和社交媒体评论,可以成为帮助临床决策和提高质量的丰富数据来源。如互联网上有基于文本的数据(例如,对医疗保健提供者的社交媒体评论),这些数据我们可…

AndroidStudio flutter 开发环境 绿色版,绿化方法

这里写自定义目录标题 绿色版下载:绿色版制作过程参考资料1.按照正常方式配置flutter开发环境(不包括桌面开发环境),确认能够正常编译apk2.移动AndroidStudio3.修改 {Android Studio安装路径}\bin\idea.properties4.移动.android5.移动AndroidSdk6.移动gradle 绿色版下载: and…

flink yarn-session 启动失败retrying connect to server 0.0.0.0/0.0.0.0:8032

原因分析&#xff0c;启动yarn-session.sh&#xff0c;会向resourcemanager的端口8032发起请求&#xff1a; 但是一直无法请求到8032端口&#xff0c;触发重试机制会不断尝试 备注&#xff1a;此问题出现时&#xff0c;我的环境ambari部署的HA 高可用hadoop&#xff0c;三个节点…

计算机网络传输层(期末、考研)

计算机网络总复习链接&#x1f517; 目录 传输层的功能端口UDP协议UDP数据报UDP的首部格式UDP校验 TCP协议&#xff08;必考&#xff09;TCP报文段TCP连接的建立TCP连接的释放TCP的可靠传输TCP的流量控制零窗口探测报文段 TCP的拥塞控制慢开始和拥塞控制快重传和快恢复 TCP和U…

低代码 —— 饮食均衡,合理膳食

目录 一、低代码的概念 二、低代码的优缺点 &#xff08;一&#xff09;优点 &#xff08;二&#xff09;缺点 三、低代码的能力 1、场景构建能力 2、数据编排能力 3、连接生态能力 4、业务中台能力 四、你认为低代码会替代传统编程吗&#xff1f; 1、从技术特征来看…

各厂家扇区电下倾识别调整方法

一、华为设备 针对华为4488天线或44天线TDD/FDD1800/FDD900电子下倾调整步骤 步骤1&#xff1a;先通过“DSP RETPORT”命令梳理全网供电开关开启状态 操作命令如下&#xff1a; &#xff08;可通过脚本执行DSP RETPORT:;命令批量提取全网信息&#xff0c;该命令是以RRU为单位…

【深度学习】强化学习(七)基于策略函数的学习方法

文章目录 一、强化学习问题1、交互的对象2、强化学习的基本要素3、策略&#xff08;Policy&#xff09;4、马尔可夫决策过程5、强化学习的目标函数6、值函数7、深度强化学习 二、基于值函数的学习方法三、基于策略函数的学习方法 一、强化学习问题 强化学习的基本任务是通过智能…

OpenCV极坐标变换函数warpPolar的使用

学更好的别人&#xff0c; 做更好的自己。 ——《微卡智享》 本文长度为1702字&#xff0c;预计阅读4分钟 前言 前阵子在做方案时&#xff0c;得了几张骨钉的图片&#xff0c;骨科耗材批号效期管理一直是比较麻烦的&#xff0c;贴RFID标签成本太高&#xff0c;所以一般考虑还是…

【教学类-06-16】20231213 (按比例抽题+乱序or先加再减后乘)X-Y之间“加法减法乘法+-×混合题”

作品展示&#xff1a; 背景需求&#xff1a; 大三班的“第一高手”对我提供的每一套的题目都只有一种反应&#xff1a; “这个是分合题&#xff0c;太简单了” “乘法&#xff0c;乘法我也会&#xff0c;11的1 22的4 33的9&#xff0c;,44十六……” “都太简单了&#xff0…

数据通信网络基础

数据通信网络基础&#xff08;1&#xff09; 一.前言 • 在人类社会的起源和发展过程中&#xff0c;通信就一直伴随着我们。从20世纪七、八十年代开始&#xff0c; 人类社会已进入到信息时代&#xff0c;对于生活在信息时代的我们&#xff0c;通信的必要性更是不言而喻 的。…

11.仿简道云公式函数实战-逻辑函数-TRUE

1. TRUE函数 TRUE 函数可直接返回逻辑值 true。 2. 函数用法 TRUE() 3. 函数示例 TRUE 函数一般不会作为函数单独使用&#xff0c;可与其他函数一起使用&#xff0c;或作为判断逻辑的结果。如&#xff0c;判断字段值是否为空时&#xff0c;设置公式为IF(ISEMPTY(方案选择)…

内网服务器部署maven私服简记

前言 很多企业希望创建自己的maven私服&#xff0c;但服务器无法和外网连通&#xff0c;所以这里介绍一套完整的内网部署nexus的解决方案。实现的方式也很简单&#xff0c;将下载好的nexus安装和项目所需的依赖仓库都上传到服务i去上去&#xff0c;通过脚本的方式实现批量导入…

基于vue实现的疫情数据可视化分析及预测系统-计算机毕业设计推荐 django

本疫情数据可视化分析及预测系统 开发&#xff0c;用小巧灵活的MySQL数据库做完后台存储解释。本系统不仅主要实现了注册登录&#xff0c;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;全国实时数据管理&#xff0c;每日实时数据管理&#xff0c;国内实时动态…

蓝牙物联网全屋智能系统解决方案

#蓝牙物联网# 蓝牙物联网全屋智能系统解决方案是一种通过低功耗蓝牙技术将家中的各种设备连接到一起&#xff0c;实现家居物联智能操控的方案。 全屋智能系统解决方案是一种将智能家居设备、传感器、照明、安防等系统集成在一起&#xff0c;实现全屋智能化控制的方案。 蓝牙物…

基于docker容器化部署微服务

前言 在笔者系列文章中微服务配置隔离已经完成服务之间的配置隔离&#xff0c;服务整体来说是已经通了。 为了方便后续测试已经环境统一&#xff0c;笔者本章节会对服务进行容器化部署。由于服务器性能问题&#xff0c;本次部署采用maven完成镜像构建&#xff0c;结合docker-c…

C#实现支付宝转账功能

环境 .net 6 AlipaySDKNet.OpenAPI 2.4.0 申请证书 登录支付宝开放平台https://open.alipay.com/ 进入控制台 授权回调地址也设置一下&#xff0c;加密方式AES 新建.net 6空白的web项目 证书除了java都需要自己生成一下pkcs1的密钥 privatekey.txt就是根据应用私钥生成…

星辰天合获评年度数智转型“优秀服务商”

近日&#xff0c;由中国智能制造百人会、中国智能制造产业网主办的“专精特新 单冠领航”-2023 制造业高质量发展大会暨数字化标准化创新高峰论坛在南京顺利举办&#xff0c;大会颁发了 2022-2023 年度数智转型“优秀服务商”奖项&#xff0c;星辰天合凭借在先进制造领域的优秀…

【论文阅读】MAKE-A-VIDEO: TEXT-TO-VIDEO GENERATION WITHOUT TEXT-VIDEO DATA

Make-a-video:没有文本-视频数据的文本-视频生成。 paper&#xff1a; code&#xff1a; ABSTRACT 优点: (1)加速了T2V模型的训练(不需要从头开始学习视觉和多模态表示)&#xff0c; (2)不需要配对的文本-视频数据&#xff0c; (3)生成的视频继承了当今图像生成模型的庞大…

SQL、Jdbc、JdbcTemplate、Mybatics

数据库&#xff1a;查询&#xff08;show、select&#xff09;、创建&#xff08;create)、使用(use)、删除(drop)数据库 表&#xff1a;创建&#xff08;【字段】约束、数据类型&#xff09;、查询、修改&#xff08;alter *add&#xff09;、删除 DML&#xff1a;增加(inse…