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

news2024/12/24 2:19:59

作品展示:

背景需求:

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

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

“乘法,乘法我也会,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,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

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

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

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

相关文章

7个常见的jmeter压测问题

根据在之前的压测过程碰到的问题&#xff0c;今天稍微总结总结&#xff0c;以后方便自己查找。 一、单台Mac进行压测时候&#xff0c;压测客户端Jmeter启动超过2000个线程&#xff0c;Jmeter报OOM错误&#xff0c;如何解决&#xff1f; 解答&#xff1a;单台Mac配置内存为8G&…

快速上手linux | 一文秒懂Linux各种常用目录命令(上)

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏:《C语言初阶篇》 《C语言进阶篇》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 文章目录 一 、命令提示符和命令的基本格式1.1 如何查看主机名称及修改 二、命令基本格式2.1 命令格式示例2.2 参数的作用…

【价值几十万的仿抖音直播电商系统源码共享】

当下&#xff0c;传统的图文电商模式已经走向没落&#xff0c;以抖音为首的直播电商模式备受用户追捧&#xff0c;它具有实时直播和强互动的特点&#xff0c;是传统电商所不具备的优势。而且&#xff0c;当前正是直播电商的红利期&#xff0c;很多主播和品牌商都通过直播电商业…

【LeetCode刷题】-- 163.缺失的区间

163.缺失的区间 class Solution {public List<List<Integer>> findMissingRanges(int[] nums, int lower, int upper) {List<List<Integer>> res new ArrayList<>();for(int num : nums){if(lower < num){res.add(Arrays.asList(lower,num -…

华为OD试题二(文件目录大小、相对开音节、找最小数)

1. 文件目录大小 题目描述&#xff1a; 一个文件目录的数据格式为&#xff1a;目录id&#xff0c;本目录中文件大小&#xff0c;(子目录id 列表)。其中目录id全局唯一&#xff0c;取值范围[1,200]&#xff0c;本目录中文件大小范 围[1,1000]&#xff0c;子目录id列表个数[0,10…

考试的最大困扰度

说在前面 &#x1f388;不知道大家对于算法的学习是一个怎样的心态呢&#xff1f;为了面试还是因为兴趣&#xff1f;不管是出于什么原因&#xff0c;算法学习需要持续保持。 1、题目描述 一位老师正在出一场由 n 道判断题构成的考试&#xff0c;每道题的答案为 true &#xff…

每日一题,杨辉三角

给定一个非负整数 numRows&#xff0c;生成「杨辉三角」的前 numRows 行。 示例 1: 输入: numRows 5 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]] 示例 2: 输入: numRows 1 输出: [[1]]

Java 语言关键字

Java关键字是电脑语言里事先定义的&#xff0c;有特别意义的标识符&#xff0c;有时又叫保留字&#xff0c;还有特别意义的变量。Java的关键字对Java的编译器有特殊的意义&#xff0c;他们用来表示一种数据类型&#xff0c;或者表示程序的结构等&#xff0c;关键字不能用作变量…

自控基础理论篇-品质因数与阻尼系数的关系

1.二阶低通滤波系数的标准形式 &#xff08;a&#xff09;与阻尼系数相关的标准形式 &#xff08;b&#xff09;与品质因数相关的标准形式 比较上式可以分析得到,当A0等于1的时候&#xff0c;阻尼比与品质因素有一个对应关系 2.二阶带通滤波系数的标准形式 &#xff08;a&…

【Java系列】详解多线程(二)——Thread类及常见方法(上篇)

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【Java系列专栏】【JaveEE学习专栏】 本专栏旨在分享学习Java的一点学习心得&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 一…

Spring Cloud gateway - CircuitBreaker GatewayFilte

前面学习Spring cloud gateway的时候&#xff0c;做测试的过程中我们发现&#xff0c;Spring Cloud Gateway不需要做多少配置就可以使用Spring Cloud LoadBalance的功能&#xff0c;比如&#xff1a; spring:application:name: spring-gatewaycloud:gateway:routes:- id: path…

20231213给Ubuntu18.04.6LTS新加一块HDD机械硬盘

20231213给Ubuntu18.04.6LTS新加一块HDD机械硬盘 2023/12/13 22:50 rootrootrootroot-X99-Turbo:~$ cat /etc/issue Ubuntu 18.04.6 LTS \n \l sudo fdisk -l rootrootrootroot-X99-Turbo:~$ rootrootrootroot-X99-Turbo:~$ sudo fdisk -lu Disk /dev/sda: 2.7 TiB, 300059298…

传输层协议介绍(三次握手,四次挥手)

一.传输层协议介绍 1.TCP协议概念 ①面向连接网络协议 ②是指通信双方之间在进行通信之前要先建立连接。比如打电话&#xff0c;双方通话前要先建立连接。 ③TCP协议是面向连接的&#xff0c;可靠的进程到进程通信的协议&#xff0c;TCP提供全双工服务&#xff0c;即数据可…

计网 - 一台主机上最多只能保持 65535 个TCP 连接吗

文章目录 Pre问题分析单一IP的服务端单一IP的客户端 Pre 高性能网络编程 - 关于单台服务器并发TCP连接数理论值的讨论 问题 一台主机上只能保持最多 65535 个 TCP 连接&#xff0c;正确吗&#xff1f; 先说结论&#xff1a; 这个说法不对&#xff0c;我们分服务器和客户端分…

2.操作符详解

1.10进制转二进制方法 所以125的二进制就是1111101 2.2进制转8进制: 从2进制序列中右边最低位开始向左每3个2进制位换算为一个8进制位&#xff0c;剩余不够3个2进制位的直接换算 例:01101011转为01 101 011 即1 5 3 即8进制的153 还原回去的话: 将3化为011放最右边,5化…

【C++进阶篇】二叉搜索数

目录 前言&#xff1a; 以后我们要学map&#xff0c;set&#xff0c;AVL&#xff0c;红黑数所以必须要有二叉搜索数做铺垫 1、二叉搜索树概念 2.二叉搜索树操作 1.二叉搜索树的查找 a、从根开始比较&#xff0c;查找&#xff0c;比根大则往右边走查找&#xff0c;比根小则…

QEMU源码全解析 —— virtio(5)

接前一篇文章&#xff1a; 本文内容参考&#xff1a; 《趣谈Linux操作系统》 —— 刘超&#xff0c;极客时间 《QEMU/KVM》源码解析与应用 —— 李强&#xff0c;机械工业出版社 特此致谢&#xff01; 上一回以virtio balloon设备为例概述了具体的virtio设备、virtio PCI代理…

Proxmox创建Windows虚拟机

文章目录 下载ISO安装文件上传 下载ISO安装文件 下载地址&#xff1a;https://www.xitongzhijia.net/ 也可去官网进行下载 上传 将下载的ISO文件上传到Proxmox 选择ISO文件进行上传 上传后再ISO镜像中可以看到安装文件 点击创建虚拟机 填写名称&#xff0c;不能填写中文 镜…

使用NCNN在华为M5部署Yolov5

使用NCNN在华为M5平板部署Yolov5 一、NCNN二、下载解压NCNN三、下载ncnn-android-yolov5工程四、下载Android Studio[前提已经配置了jdk版本]1、安装NDK、Cmske&#xff0c;这个必须要安装&#xff0c;2、安装Android 五、构建工程六、修改源码七、重新ysnc project八、安装APP…

18个非技术面试题

请你自我介绍一下你自己&#xff1f; 这道面试题是大家在以后面试过程中会常被问到的&#xff0c;那么我们被问到之后&#xff0c;该如果回答呢&#xff1f;是说姓名&#xff1f;年龄&#xff1f;还是其他什么&#xff1f; 最佳回答提示&#xff1a; 一般人回答这个问题往往会…