【教学类-06-16】20231213 (按比例抽题+乱序or先加再减后乘)X-Y之间“加法减法乘法+-×混合题”
2023-12-13 23:19:48
作品展示:
背景需求:
大三班的“第一高手”对我提供的每一套的题目都只有一种反应:
“这个是分合题,太简单了”
“乘法,乘法我也会,11的1 22的4 33的9,,44十六……”
“都太简单了,我不想做。”
……
老师感叹:“你太聪明了,这些题目都不适合你!”
他骄傲地回答,“不是我太聪明,是你的题目太简单了!”
o(╥﹏╥)o”
我们讨论了一下题目难度,最后他说:“我还不会除法,但是我会“加减乘””
“那专门给你一份‘加减乘’混合题,行吗?”
“好的!你下次来给我哦”
思考:
想到“加、减、×”,我感觉三种题型的话,是不是要控制一下出题数量的比例,比如他非常熟悉的加法减法少一点,让乘法多一点。让做题时间延长一点。
根据“下面加减+-混合”按比例出题的思路,我又加了一块乘法到下面的表格中,顺利做出了“加法VS减法VS乘法”比例混合题
WORD模板
使用55格、一页两份的WORD样式
代码展示:
'''
X-Y 之间的所有加减乘+-×混合法题(如10-20之间的所有加法+减法+乘法,10+0,10+1,10-0,1*1)
1、按比例抽题:
2、考虑“乱序(加法减法乘法混合)和先加后减后乘 ”两种排列方法
3、加减乘 3:3:4
时间: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('加法题抽取(输3。3:3:4,加法抽取30%,减法抽取30%,乘法40%)\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(sum2+1): # 起始数字就是10,就是排除掉0-10之间的数字
for b in range(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
# 乘法
chen=[]
for a in range(0,sum2+1): # 从0开始
for b in range(0,sum2+1): # 起始数字为0,
if sum1<=a*b<=sum2*sum2: # =9*9-81
# print('{}+{}='.format(a,b))
chen.append('{}×{}='.format(a,b))
chen.append('{}×{}='.format(b,a))
else:
pass
P=len(jian)+len(jia)+len(chen)
print(P)# 0-5加法减法题目总数42
L=jia+jian+chen
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=tl1
tl3=gz-tl1-tl2
print(tl2)
title='{}-{}“+-×”{}抽{}题{}:{}:{}'.format(sum1,sum2,P,gz,bl,bl,int(10-bl*2))
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: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)
C3=random.sample(chen,tl3)
for cc3 in C3:
D.append(cc3)
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)
C3=random.sample(chen,tl3)
for cc3 in C3:
D.append(cc3)
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,bl,10-bl*2,'%03d'%P,'%02d'%P,c,num,n))
else: # 先加后减
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“+-×”(一页两份 ){}题{}-{}之间正逆“+-×”数量{}比{}比{}顺序加减乘(共{}题抽{}题)({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,bl,bl,10-bl*2,'%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,bl,10-bl*2,'%03d'%P,gz,c,num,n))
else: # 先加后减
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)03“+-×”(一页两份 ){}题{}-{}之间正逆“+-×”数量{}比{}比{}顺序加减乘(共{}题抽{}题)({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,bl,bl,10-bl*2,'%03d'%P,gz,c,num,n))
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/加减法/零时Word') #递归删除文件夹,即:删除非空文件夹
考虑到三类题目混合,题量肯定大于55题,所以以下这部分没有仔细推算。
因为明天我带全天班(上午中3,下午大3)所以只做了3:3:4的比例。有空再看看其他比例是否会出错。
先做一套“现加再减后乘”判断题量是否正确,3:3:4=16:16:17
再做一套“乱序”验证题量是否正确,3:3:4=16:16:17
明天打印几份给“高手们”玩一玩。
文章来源:https://blog.csdn.net/reasonsummer/article/details/134983085
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!