【教学类-06-09】20231126 X-Y数字分合-分-下空右

结果展示:

背景需求:

1、加减法理论上在幼儿园不适用(虽然实际上幼儿在家早就练习了)

2、分合题是大班教学数上涉及的内容,可以尝试(类似于减法、加法)可以用雪花片等实物进行增加、减少。------实物计算

代码展示:

python 复制代码
'''
X-Y 之间的分合题-分-空在右侧
时间:2023年11月26日 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'))
gz=56 # A4最大49题 7列8行
# classroom=input('班级(输入中、大)\n')
size=20
# height1=
# weight1=5
sum1=int(input('X-Y以内的"+" 最小数字X\n'))
sum2=int(input('X-Y以内的"+" 最大数字Y\n'))



# 5以内"+"题共21题
P=[]
for a in range(sum1,sum2+1):     # 起始数字就是10,就是排除掉0-10之间的数字
    for b in range(sum1,sum2+1):      # 起始数字为0,
        if sum1<=a+b<sum2+1:  
            P.append('{}{}'.format('%02d'%(a+b),'%02d'%a))  
            P.append('{}{}'.format('%02d'%(a+b),'%02d'%b))  
        else:
            pass

P =list(set(P))    # 排除重复,但随机打乱
P.sort()    # 小到大排序
print(P)
    # ['0000', '0100', '0101', '0200', '0201', '0202', '0300', '0301', '0302', '0303', '0400', '0401', '0402', '0403', '0404', '0500', '0501', '0502', '0503', '0504', '0505']
    # "+"题生成都是按小到大排列的,不需要sort排序
print('{}-{}之间的加法题共有  {}  题'.format(sum1,sum,len(P)) )   # 42


# 第一行的班级和项目

    
A=[]
# c='{}'.format(classroom)

if len(P) <=gz:
    title='{}-{}分合题-分(下右)共{}抽{}题'.format(sum1,sum2,len(P),len(P))
if len(P) >gz:
    title='{}-{}分合题-分(下右)共{}抽{}题'.format(sum1,sum2,len(P))
d=['0004']
# 表格0 表格2的 03 05单元格里写入标题信息c
# A.append(c)
A.append(title)
print(A)

# 制作"单元格"
bgall=[]
for bb in d:
    bgall.append(bb)

ts=[]
# 先计算合并行的坐标格
for x in range(1,24,3):    
    for y in range(0,14,2):            
        s1='{}{}'.format('%02d'%x,'%02d'%y)       # 数字加空格
        ts.append(s1)   
print(ts)        
print(len(ts))

# 再计算左侧分1数字的坐标格
for w in range(3,27,3):    
    for v in range(0,14,2):            
        s2='{}{}'.format('%02d'%w ,'%02d'%v)       # 数字加空格
        ts.append(s2)   
print(ts)        
print(len(ts))
# 112

c=int(len(ts)/2)
print(c)
# 56

b=[]
# 单元格逐一加入合并坐标格和左份1做表格
for p in range(0,c):
    bgall.append(ts[p])    # 写入0格1格
    bgall.append(ts[p+c]) # 写入56格57格
print(bgall)


# 不同情况下的单元格数量
if len(P) <=gz:
    bg=bgall[0:1+int(len(P)*2)]    # 分合题一题插入两个格子,所以多提取一些单元格坐标
    print(bg)
    print(len(bg))
else:
    bg=bgall[0:1+int(len(bgall)*2)]  # 分合题一题插入两个格子,所以多提取一些单元格坐标
    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)
for z in range(0,n):   #多少份  
    # 新建word
    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\分合题\分合-分-右.docx')  
    D.clear()
    if len(P) <=gz:
    # D=[]
    # 小于9的题目,要计算一共有几题,写入等量的单元格内, 
        for xx in A :
            D.append(xx)
    
        C=random.sample(P,len(P))  
        for cc in C:
            D.append(int(cc[0:2]))            # 合集总数
            D.append(int(cc[2:4]))            # 左下分数1

        print(D)
        print(len(D))

    else:
    # D=[]
    # 大于9的题目,只要抽取55题,多余的写不下,
        for xx in A :
            D.append(xx) 
        C=random.sample(P,len(bgall))              # 55格
        for cc in C:
            D.append(int(cc[0:2]))            # 合集总数
            D.append(int(cc[2:4]))      # 左下分数1
        print(D)
        print(len(D))


#       # 房间模板(第一个表格)要写入的门牌号列表 
    table = doc.tables[0]          # 表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(20) #是否加粗
        # 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.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)

if len(P) <=gz:
    file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/分合题/(打印合集)01"+"(一页两份 ){}题{}-{}之间分合-分-下右共{}题抽{}题({}共{}人打印{}张).pdf" .format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P),'%02d'%len(P),c,num,n))
else:
    file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/分合题/(打印合集)01"+"(一页两份 ){}题{}-{}之间分合-分-下右共{}题抽55题({}共{}人打印{}张).pdf".format(gz,'%02d'%sum1,'%02d'%sum2,'%03d'%len(P),c,num,n))

file_merger.close()
# doc.Close()

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

把各种坐标的位置确定好(合并格以最左侧的格子坐标为准)

WORD模板

表格里面:

总数的位置需要合并,右侧空的位置需要加入回车符,然后选中加入下划线

结果展示

1-9 分合-分 36题(合计不超过9)

0-9 分合-分55题(合计不超过9)

相关推荐
M_emory_4 分钟前
解决 git clone 出现:Failed to connect to 127.0.0.1 port 1080: Connection refused 错误
前端·vue.js·git
Ciito7 分钟前
vue项目使用eslint+prettier管理项目格式化
前端·javascript·vue.js
成都被卷死的程序员41 分钟前
响应式网页设计--html
前端·html
mon_star°1 小时前
将答题成绩排行榜数据通过前端生成excel的方式实现导出下载功能
前端·excel
Zrf21913184551 小时前
前端笔试中oj算法题的解法模版
前端·readline·oj算法
文军的烹饪实验室2 小时前
ValueError: Circular reference detected
开发语言·前端·javascript
Martin -Tang3 小时前
vite和webpack的区别
前端·webpack·node.js·vite
迷途小码农零零发3 小时前
解锁微前端的优秀库
前端
王解4 小时前
webpack loader全解析,从入门到精通(10)
前端·webpack·node.js
我不当帕鲁谁当帕鲁4 小时前
arcgis for js实现FeatureLayer图层弹窗展示所有field字段
前端·javascript·arcgis