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

作品展示:

背景需求:

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

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

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

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

……

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

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

o(╥﹏╥)o”

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

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

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

思考:

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

根据“下面加减+-混合”按比例出题的思路,我又加了一块乘法到下面的表格中,顺利做出了“加法VS减法VS乘法”比例混合题

【教学类-06-15】20231213 (按比例抽题+乱序or先加后减)X-Y之间“加法减法+-题”-CSDN博客文章浏览阅读115次,点赞4次,收藏4次。【教学类-06-15】20231213 (按比例抽题+乱序or先加后减)X-Y之间“加法减法+-题”https://blog.csdn.net/reasonsummer/article/details/134969072

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,timeimport 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 qnfrom 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:passP=len(jian)+len(jia)+len(chen)
print(P)# 0-5加法减法题目总数42L=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,单元格数量55print('数学题总数大于55,实际题目数量{}'.format(gz))sl=Ptl1=int(gz*bl*10/100)     # 加法题的题量是 21*50/100  可能是浮点数10.5,所以要用int=10print(tl1)tl2=tl1tl3=gz-tl1-tl2print(tl2)title='{}-{}“+-×”{}抽{}题{}:{}:{}'.format(sum1,sum2,P,gz,bl,bl,int(10-bl*2))if P<=gz:    # 0-5等于42题,小于于55,单元格数量42print('数学题总数小于55,实际题目数量{}'.format(P))sl=Ptl1=len(jia)    # 加法题的题量是 21*50/100  可能是浮点数10.5,所以要用int=11print(tl1)tl2=P-tl1print(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):   #多少份  # 标题说明# 新建worddoc = 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,先出加法,再出减法passprint(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,先出加法,再出减法passprint(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-255run.font.color.rgb = RGBColor(150,150,150) #数字小,颜色深0-255run.bold=True# paragraph.paragraph_format.line_spacing = Pt(180) #数字段间距r = run._elementr.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

明天打印几份给“高手们”玩一玩。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于linux系统的Tomcat+Mysql+Jdk环境搭建(三)centos7 安装Tomcat

Tomcat下载官网&#xff1a; Apache Tomcat - Which Version Do I Want? JDK下载官网&#xff1a; Java Downloads | Oracle 中国 如果不知道Tomcat的哪个版本应该对应哪个版本的JDK可以打开官网&#xff0c;点击Whitch Version 下滑&#xff0c;有低版本的&#xff0c;如…

设计模式(3)--对象结构(3)--组合

1. 意图 将对象组合成树形结构以表示“部分-整体”的层次结构。Composite使得用户对单个对象和组合对象的使用具有一致性。 2. 三种角色 抽象组件(Component)、组合式节点(Composite)、叶节点(Leaf) 3. 优点 3.1 定义了包含基本对象和组合对象的类层次结构。 客户代码中&…

C++相关闲碎记录(14)

1、数值算法 &#xff08;1&#xff09;运算后产生结果accumulate() #include "algostuff.hpp"using namespace std;int main() {vector<int> coll;INSERT_ELEMENTS(coll, 1, 9);PRINT_ELEMENTS(coll);cout << "sum: " << accumulate(…

Spring入门

学习的最大理由是想摆脱平庸&#xff0c;早一天就多一份人生的精彩&#xff1b;迟一天就多一天平庸的困扰。各位小伙伴&#xff0c;如果您&#xff1a; 想系统/深入学习某技术知识点… 一个人摸索学习很难坚持&#xff0c;想组团高效学习… 想写博客但无从下手&#xff0c;急需…

鸿蒙ArkTS Web组件加载空白的问题原因及解决方案

问题症状 初学鸿蒙开发&#xff0c;按照官方文档Web组件文档《使用Web组件加载页面》示例中的代码照抄运行后显示空白&#xff0c;纠结之余多方搜索后扔无解决方法。 运行代码 import web_webview from ohos.web.webviewEntry Component struct Index {controller: web_webv…

docker入门小结

docker是什么&#xff1f;它有什么优势&#xff1f; 快速获取开箱即用的程序 docker使得所有的应用传输就像我们日常通过聊天工具文件传输一样&#xff0c;发送方将程序传输到超级码头而接收方也只需通过超级码头进行获取即可&#xff0c;就像一只鲸鱼拖着货物来回运输一样。…

使用java获取nvidia显卡信息

前言 AI开发通常使用到GPU&#xff0c;但通常使用的是python、c等语言&#xff0c;java用的则非常少。这也导致了java在gpu相关的库比较少。现在的需求是要获取nvidia显卡的使用情况&#xff0c;如剩余显存。这里给出两种较简单的解决方案。 基于nivdia-smi工具 显卡是硬件&a…

AMD 自适应和嵌入式产品技术日

概要 时间&#xff1a;2023年11月28日 地点&#xff1a;北京朝阳新云南皇冠假日酒店 主题内容&#xff1a;AMD自适应和嵌入式产品的更新&#xff0c;跨越 云、边、端的AI解决方案&#xff0c;赋能智能制造的机器视觉与机器人等热门话题。 注&#xff1a;本文重点关注FPGA&a…

【51单片机系列】直流电机使用

本文是关于直流电机使用的相关介绍。 文章目录 一、直流电机介绍二、ULN2003芯片介绍三、在proteus中仿真实现对电机的驱动 51单片机的应用中&#xff0c;电机控制方面的应用也很多。在学习直流电机(PWM)之前&#xff0c;先使用GPIO控制电机的正反转和停止。但不能直接使用GPIO…

textarea 网页文本框在光标处添加内容

在前端研发中我们经常需要使用脚本在文本框中插入内容。如果产品要求不能直接插入开始或者尾部&#xff0c;而是要插入到光标位置&#xff0c;此时我们就需要获取光标/光标选中的位置。 很多时候&#xff0c;我在格式化文本处需要选择选项&#xff0c;将选择的信息输入到光标位…

关于“Python”的核心知识点整理大全25

目录 10.3.4 else 代码块、 10.3.5 处理 FileNotFoundError 异常 alice.py 在这个示例中&#xff0c;try代码块引发FileNotFoundError异常&#xff0c;因此Python找出与该错误匹配的 except代码块&#xff0c;并运行其中的代码。最终的结果是显示一条友好的错误消息&#x…

基于循环神经网络长短时记忆(RNN-LSTM)的大豆土壤水分预测模型的建立

Development of a Soil Moisture Prediction Model Based on Recurrent Neural Network Long Short-Term Memory in Soybean Cultivation 1、介绍2、方法2.1 数据获取2.2.用于预测土壤湿度的 LSTM 模型2.3.土壤水分预测的RNN-LSTM模型的建立条件2.4.预测土壤水分的RNN-LSTM模型…

【ArkTS】Watch装饰器

Watch装饰器&#xff0c;相当于Vue中的监听器 以及 React中使用useEffect监听变量 使用Watch装饰器&#xff0c;可以监听一个数据的变化&#xff0c;并进行后续的响应。 使用方法&#xff1a; Watch(‘回调函数’)&#xff0c;写在State装饰器后&#xff08;其实写在前面也行&a…

LabVIEW开发地铁运行安全监控系统

LabVIEW开发地铁运行安全监控系统 最近昌平线发生的故障事件引起了广泛关注&#xff0c;暴露了现有地铁运行监控系统在应对突发情况方面的不足。为了提高地铁系统的运行安全性&#xff0c;并防止类似事件再次发生&#xff0c;提出了一套全面的地铁运行安全监控系统方案。此方案…

[Verilog] Verilog 基本格式和语法

主页&#xff1a; 元存储博客 全文 3000 字 文章目录 1. 声明格式1.1 模块声明1.2 输入输出声明1.3 内部信号声明1.4 内部逻辑声明1.5 连接声明1.6 数据类型声明1.7 运算符和表达式1.8 控制结构 2. 书写格式2.1 大小写2.2 换行2.3 语句结束符2.4 注释2.5 标识符2.6 关键字 1. 声…

python/c++ Leetcode题解——746. 使用最小花费爬楼梯

目录 方法一&#xff1a;动态规划 复杂度分析 方法一&#xff1a;动态规划 假设数组 cost 的长度为 n&#xff0c;则 n 个阶梯分别对应下标 0 到 n−1&#xff0c;楼层顶部对应下标 n&#xff0c;问题等价于计算达到下标 n 的最小花费。可以通过动态规划求解。 创建长度为 n…

【面试】测试/测开(NIG2)

145. linux打印前row行日志 参考&#xff1a;linux日志打印 前10行日志 head -n 10 xx.log后10行日志 tail -n 10 xx.log tail -10f xx.log使用sed命令 sed -n 9,10p xx.log #打印第9、10行使用awk命令 awk NR10 xx.log #打印第10行 awk NR>7 && NR<10 xx.log …

爬虫 selenium语法 (八)

目录 一、为什么使用selenium 二、selenium语法——元素定位 1.根据 id 找到对象 2.根据标签属性的属性值找到对象 3.根据Xpath语句获取对象 4.根据标签名获取对象 5.使用bs语法获取对象 6.通过链接文本获取对象 三、selenium语法——访问元素信息 1.获取属性的属性值…

MySQL 常用数据类型总结

面试&#xff1a; 为什么建表时,加not null default ‘’ / default 0 答:不想让表中出现null值. 为什么不想要的null的值 答:&#xff08;1&#xff09;不好比较,null是一种类型,比较时,只能用专门的is null 和 is not null来比较. 碰到运算符,一律返回null &#xff08…

ES-模糊查询

模糊查询 1 wildcard 准备数据 POST demolike/_bulk {"index": {"_id": "1"} } {"text": "草莓熊是个大坏蛋" } {"index": {"_id": "2"} } {"text": "wolf 也是一个坏蛋&q…