【教学类-30-04】10以内减法题不重复(一页两份)(包括6以内、7以内、8以内、9以内、10以内减法题 只抽取25个)

news/2024/7/5 5:53:09

作品展示 ——10以内不重复减法题

需求:

1、制作10以内减法题

材料准备:

 Word模板

代码展示:

'''
6、7、8、9、10以内减法一页两份(10以内减法一页两份(6以内、7以内、8以内、9以内、10以内不重复减法题)
时间:2023年4月8日 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('打印几份(输入28人,实际14份)\n'))
size=int(input('字体大小(25)\n'))
height1=int(input('单元格高度(5行)\n'))
weight1=int(input('单元格宽度(5列)\n'))
sum=int(input('X以内的(6以内、7以内、8以内、9以内、10以内)\n'))
classroom=input('班级(输入中6)\n')

# 6以内:28
# 7以内:36
# 8以内:45
# 9以内:55
# 10以内:66

# 5以内减法题共21题
S=[]
for a in range(sum+1):
    for b in range(sum+1):
        if 0<=a-b<sum+1:              
            # print('{}+{}='.format(a,b))
            S.append('{}-{}='.format(a,b))
        if 0<=b-a<sum+1:  
            S.append('{}-{}='.format(b,a))         
# print(S)
S=list(set(S))    # 去除重复
S.sort()     # 排序
print(S)    
# ['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(len(S))     # 21
# ['0+0=', '0+1=', 

# 新建一个”装N份word和PDF“的临时文件夹
os.mkdir(r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\零时Word')



n=int(num/2)
for z in range(0,n):   #多少份  
    # 新建word
    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\加减法\01加法模板一页两份(6-10以内加法).docx')  
    for j in range(2):        # 0,1
       
        # 标题说明
        D=[]
        c='{}班'.format(classroom)
        title='{}以内不重复减法{}题抽{}题 '.format(sum,len(S),height1*weight1)
        d=['03','05']
        # 表格0 表格2的 03 05单元格里写入标题信息c
        D.append(c)
        D.append(title)
        print(D)
       
        # 制作"单元格"
        N=[]
        for x in range(0,height1):   
            for y in range(0,weight1):            
                s1='{}{}'.format(x,y)       # 数字加空格
                N.append(s1)   
        print(N)        
        # ['00', '01', '02', '03', '04', '10', '11', '12', '13', '14', '20', '21', '22', '23', '24', '30', '31', '32', '33', '34', '40', '41', '42', '43', '44']
        bg=N[0:len(S)]        # 只要21个单元格
        print(bg)
        # ['00', '01', '02', '03', '04', '10', '11', '12', '13', '14', '20', '21', '22', '23', '24', '30', '31', '32', '33', '34', '40']

        # 索引数字 随机抽取25个数字 
        C=random.sample(S,height1*weight1)  
        print(C)


#       # 房间模板(第一个表格)要写入的门牌号列表 
        table = doc.tables[j*2]          # 表0,表2
        # 标题写入3、5单元格  
        for t2 in range(0,len(d)):             # 0-5是最下面一行,用来写卡片数字
            pp2=int(d[t2][0])     # 
            qq2=int(d[t2][1])
            k2=D[t2]                  # 提取list图案列表里面每个图形  t=索引数字
            print(pp2,qq2,k2)

            run=table.cell(pp2,qq2).paragraphs[0].add_run(k2)    # 在单元格0,0(第2行第2列)输入第0个图图案
            run.font.name = '微软雅黑'#输入时默认华文彩云字体
            run.font.size = Pt(15)  #输入字体大小默认30号
            run.bold=True
            run.font.color.rgb = RGBColor(200,200,200) #数字小,颜色深0-255
            run.font.underline = False          # 下划线
            # paragraph.paragraph_format.line_spacing = Pt(280) #数字段间距

            r = run._element
            r.rPr.rFonts.set(qn('w:eastAsia'), '微软雅黑')#将输入语句中的中文部分字体变为华文行楷

        table = doc.tables[j*2+1]          # 表1,表3
        for t1 in range(0,len(bg)):             # 0-5是最下面一行,用来写卡片数字
            pp1=int(bg[t1][0])     # 
            qq1=int(bg[t1][1])
            k1=C[t1]                  # 提取list图案列表里面每个图形  t=索引数字
            print(pp1,qq1,k1)

            run=table.cell(pp1,qq1).paragraphs[0].add_run(k1)    # 在单元格0,0(第1行第1列)输入第0个图图案
            run.font.name = '微软雅黑'#输入时默认华文彩云字体
            run.font.size = Pt(size)  #输入字体大小默认30号
            run.bold=True
            run.font.color.rgb = RGBColor(200,200,200) #数字小,颜色深0-255
            run.font.underline = False          # 下划线
            # paragraph.paragraph_format.line_spacing = Pt(180) #数字段间距

            r = run._element
            r.rPr.rFonts.set(qn('w:eastAsia'), '微软雅黑')#将输入语句中的中文部分字体变为华文行楷
#             table.cell(pp1,qq1).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中   

    
# #    
    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 PdfFileMerger
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 = PdfFileMerger()
for pdf in pdf_lst:
    print(pdf)
    file_merger.append(pdf)
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/加减法/(打印合集)02减法(一页两份 ){}以内减法共{}题抽{}题({}共{}人打印{}张).pdf".format(sum,len(S),height1*weight1,c,num,n))

file_merger.close()
# doc.Close()

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





    
    

 重点说明:

获得所有不重复的排序的5以内减法题目列表a-b b-a

 

终端输入

  

 作品展示——10以内减法

 作品展示——9以内减法

 

作品展示——8以内减法

 

作品展示——7以内减法

 

作品展示——6以内减法

 

 规律:同一个数字(X以内),无论加法还是减法,不重复数量相同

X以内

加法题/减法题不重复数量

抽取数量(25格)

1

3

3

2

6

6

3

10

10

4

15

15

5

21

21

6

28

25

7

36

25

8

45

25

9

55

25

10

66

25


http://lihuaxi.xjx100.cn/news/1002470.html

相关文章

高级UI之Android事件分发机制原理及源码分析

前言 在 Android 中&#xff0c;事件分发机制是一块很重要的知识点&#xff0c; 掌握这个机制能帮你在平时的开发中解决掉很多的 View 事件冲突问题&#xff0c;这个问题也是面试中问的比较多的一个问题了&#xff0c;本篇就来总结下这个知识点。 事件分发原因 Android 中页…

【高级语言程序设计】第 6 章:函数

目录 一、函数的概念和模块化程序设计 &#xff08;1&#xff09;C 语言函数的特点 &#xff08;2&#xff09;C 语言函数的分类 &#xff08;3&#xff09;C 语言函数的概念 &#xff08;4&#xff09;函数的一般格式 ① 函数组成 ② 函数定义的一般形式 ③ 函数首部…

#centos系统如何查看是否安装了mysql#

查看是否安装mysql yum list installed mysql* rpm -qa | grep mysql* centos卸载 mariadba rpm -e 软件包名 -nodepets 批量安装软件包rpm rpm -ivh --force --nodeps *.rpm

托福高频真词List14 // 附托福TPO阅读真题

4.3单词 生词 perishablelikely to decayadj.易腐蚀的defineidentifyv.确定&#x1f337;meticulouslycarefullyadv.细致地&#x1f337; mechanismeans n.机制secureget&#x1f337;v.争取到observemonitorv.观察overseesupervisev.监督surpassexceedbe higher thanv.超过h…

taro之--自定义编译

自定义编译​ 在特定的情况下&#xff0c;Taro 自带的编译系统没有办法满足我们的编译需求&#xff0c;这时 Taro 提供了两种拓展编译的方案&#xff1a; 使用 Webpack 进行拓展​ 在打包体积分析 中我们在 mini.webpackChain 添加了一个 Webpack 插件&#xff0c;达到了打包…

解决编译报错:File format not recognized Makefile:99: *** missing separator. Stop.方法总结

项目场景&#xff1a; 提示&#xff1a;这里简述项目相关背景&#xff1a; linux项目编译时报错如下&#xff1a; mips-v720s229-linux-gnu-strip:/home/lib/libgcc_s.so: File format not recognized Makefile:99: *** missing separator. Stop. 原因分析&#xff1a; 【1】…

技术分享| 什么是动态更新?

近期工作提到动态更新比较多&#xff0c;今天也借此机会&#xff0c;梳理一下相关的机制原理同大家分享。 动态机制及技术原理 动态研发模式就是一种基于云端的移动应用开发方法&#xff0c;主要能让开发者快速构建和发布多端的移动应用&#xff0c;实现业务的敏捷迭代和热更…

监控专题zabbix

官网&#xff1a;zabbix.com 官网源可以去阿里云镜像&#xff0c;然后单独用一台服务器连接外网使用reporsync同步repo本地源 就可以实现内网的源更新了 vim /etc/repos.d/zabbix.repo reporsync --repoid仓库名称 同步更新仓库源 一、zabbix服务器安装 1、安装zabbix和m…