【教学类-06-12】20231202 0-9数字分合-房屋样式(一)-下右空-升序-抽7题

作品展示-屋顶分合(0-9之间随机抽取7个不重复分合)

背景需求:

大班幼儿学分合题,通常区角里会设计一个“房屋分合”的样式

根据这种房屋样式,设计0-9内的升序分合题模板

素材准备

WORD样式

代码展示:

'''
2-9之间随机抽取7个数字-房屋分合题-合-空在下,房屋
时间:2023年12月02日 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'))
tm=7 # 只能抽取7题
# classroom=input('班级(输入中、大)\n')
size=20
# height1=
# weight1=5
sum1=int(input('X-Y以内的最小数字X(0-9)\n'))
sum2=int(input('X-Y以内的最大数字Y(0-9)\n'))


print('-----------第1步 制作基础题型-----------')

# 5以内“+”题共21题
P=[]
P1=[]
LIST=[]

for l in range(sum1,sum2+1):
    P.clear()
    # Q.clear()
    for a in range(0,sum2+1):     # 起始数字就是10,就是排除掉0-10之间的数字
        for b in range(0,sum2+1):     # 起始数字就是10,就是排除掉0-10之间的数字
            
            if a+b==l:  
                P.append('{}'.format(a) )
                P.append('{}'.format(b) )       
                # P1.append('{}+{}={}'.format(a,b,l) )
                # P1.append('{}+{}={}'.format(b,a,l) )           
            else:
                pass

        Q =list(set(P))    # 排除重复,但随机打乱
        Q.sort()    # 小到大排序       
    # print(Q)
    LIST.append(Q)

for x in LIST:
    print(x)

# ['0+0=0']
# ['0+1=1', '1+0=1']
# ['0+2=2', '1+1=2', '2+0=2']
# ['0+3=3', '1+2=3', '2+1=3', '3+0=3']
# ['0+4=4', '1+3=4', '2+2=4', '3+1=4', '4+0=4']
# ['0+5=5', '1+4=5', '2+3=5', '3+2=5', '4+1=5', '5+0=5']
# ['0+6=6', '1+5=6', '2+4=6', '3+3=6', '4+2=6', '5+1=6', '6+0=6']
# ['0+7=7', '1+6=7', '2+5=7', '3+4=7', '4+3=7', '5+2=7', '6+1=7', '7+0=7']
# ['0+8=8', '1+7=8', '2+6=8', '3+5=8', '4+4=8', '5+3=8', '6+2=8', '7+1=8', '8+0=8']
# ['0+9=9', '1+8=9', '2+7=9', '3+6=9', '4+5=9', '5+4=9', '6+3=9', '7+2=9', '8+1=9', '9+0=9']


 

# print('-----------第2步 单元格制作-----------')


# 屋顶总数的坐标(虽然居中,但实际坐标也是10)和左侧数字的坐标(30、40)写在一起,
bgb=[]
for y in range(0,14,2):       
    for l in range(1,13):    
        if l==2:     #  索引2(第3行)是“/\”的符号,不要写入,跳过
            pass
        else:   
            s1='{}{}'.format('%02d'%l,'%02d'%y)       # 数字加空格
            bgb.append(s1) 
print(bgb)
print(len(bgb))
# 77

# 11个格子一组
bg=[]
u=int(len(bgb)/(tm)) #11个
for q in range(int(tm)):
    bg.append(bgb[q*u:q*u+u])
print(bg)
print(len(bg))
# [['0100', '0300', '0400', '0500', '0600', '0700', '0800', '0900', '1000', '1100', '1200'],
# ['0102', '0302', '0402', '0502', '0602', '0702', '0802', '0902', '1002', '1102', '1202'],
# ['0104', '0304', '0404', '0504', '0604', '0704', '0804', '0904', '1004', '1104', '1204'],
# ['0106', '0306', '0406', '0506', '0606', '0706', '0806', '0906', '1006', '1106', '1206'],
# ['0108', '0308', '0408', '0508', # '0608', '0708', '0808', '0908', '1008', '1108', '1208'], 
# ['0110', '0310', '0410', '0510', '0610', '0710', '0810', '0910', '1010', '1110', '1210'],
# ['0112', '0312', '0412', '0512', '0612', '0712', '0812', '0912', '1012', '1112', '1212']]





# 新建一个”装N份word和PDF“的临时文件夹
imagePath1=r'C:\Users\jg2yXRZ\OneDrive\桌面\分合题\零时Word'
if not os.path.exists(imagePath1):  # 判断存放图片的文件夹是否存在
    os.makedirs(imagePath1)  # 若图片文件夹不存在就创建

print('-----------第3步 随机抽取题目,考虑格子的数量,确认坐标重新提取格子-----------')
# D=[]

# n=int(num/2)
for z in range(0,int(num/2)):   #多少份  
    # 新建word
    doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\分合题\04分合-分-下-房屋.docx')  
    # .clear()
    for j in range(2):
        table = doc.tables[j]          # 表0,表2 写标题用的
        # D=[]
        # 小于9的题目,要计算一共有几题,写入等量的单元格内, 
            # for xx in A :
            #     D.append(xx)
            # # # 第一行的班级和项目

        title='{}-{}抽取{}题 房屋分合 升序'.format(sum1,sum2,tm)
        d='0004'
        
            
        C=random.sample(LIST,tm) 
        print('随机抽取[[],[]]----{}'.format(C))
        # 随机抽了9、3、7、8、2、6、1 一共7个数字的所有题目)
        # [['0+9=9', '1+8=9', '2+7=9', '3+6=9', '4+5=9', '5+4=9', '6+3=9', '7+2=9', '8+1=9', '9+0=9'], 
        # ['0+3=3', '1+2=3', '2+1=3', '3+0=3'],
        #  ['0+7=7', '1+6=7', '2+5=7', '3+4=7', '4+3=7', '5+2=7', '6+1=7', '7+0=7'], 
        # ['0+8=8', '1+7=8', '2+6=8', '3+5=8', '4+4=8', '5+3=8', '6+2=8', '7+1=8', '8+0=8'], 
        # ['0+2=2', '1+1=2', '2+0=2'],
        #  ['0+6=6', '1+5=6', '2+4=6', '3+3=6', '4+2=6', '5+1=6', '6+0=6'], 
        # ['0+1=1', '1+0=1']]

        # 提取7题每题里面屋顶总数
        sl=[]
        for e in range(int(len(C))):
            f=int(len(C[e]))    # 提取7题每题里面屋顶总数 如果体量是5题,数字就是4
            sl.append(f)
        print('提取7题每题里面数量{}'.format(sl))
        # 7题,每一题里面包含的数量 做少1题=0,最多10题=9
        # [10, 4, 7, 8, 9, 3, 1]

        # 提取随机抽数后的每题的等量坐标格子
        bgall=[]
        # 提取等量的坐标
        # 屋顶数量=数量-1
        for s in range(len(sl)):     # 7个
            for h in bg[s][:int(sl[s]+1)]:
                bgall.append(h)    # 添加全部坐标列表bg的第一组列表里面所有题目的0-X个坐标,因为包含了屋顶坐标,所以坐标组还要加1
      
        bgall.insert(0,d)        # 在0第一个位置插入标题的坐标
        print('提取坐标总量{}'.format(bgall))
        print(len(bgall))

        # 提取要输入格子的题目数字 一个总数 X个01234
        K=[]
        # 屋顶数量=数量-1
        for u in range(len(sl)):     # 7个
            # u.append(int(sl-1))   # 屋顶写入的数字
            K.append(str(sl[u]-1))   # 写入屋顶总数,需要减去1
            for g in C[u]:        # 单个元素添加
                K.append(g)   # 添加全部题目列表C的第一组列表里面所有题目的0的数字(这里都是1位数,所以提取0)    
        
        K.insert(0,title)        # 在0第一个位置插入标题的文字
        print(K)
        print(len(K))


        

        # 标题写入3、5单元格  
        for t in range(0,len(bgall)):             # 0-5是最下面一行,用来写卡片数字
            pp=int(bgall[t][0:2])     # 
            qq=int(bgall[t][2:4])
            k=K[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(25) #是否加粗
            # run.font.color.rgb = RGBColor(150,150,150) #数字小,颜色深0-255
            run.font.color.rgb = RGBColor(100,100,100) #数字小,颜色深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)

file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/分合题/(打印合集)01“+”(一页两份 ){}-{}之间分合屋顶抽{}题 右空({}人打印{}张).pdf" .format('%02d'%sum1,'%02d'%sum2,tm,num,int(num/2)))

   
file_merger.close()
# doc.Close()

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

终端输入

左侧列,从小到大排序(0-Y)

结题思路:

1、生成0-9之间的所有加法题、去重、排序

2、把所有的可能写入数值得坐标都写出来,并做成11个一组

3、从10组加减法题目中,随机抽取7组列表,计算T每个列表的长度(题目数量)

4、确定需要写入的坐标的范围、确定需要写入数据的内容

5、写入Word

存在问题:

1、模板默认右侧列全部有下划线,最好左侧列有数字,右侧列有下划线,左侧没有数字,右侧就是空白

解决思路1——为啥一定要下划线呢?既然周围已经包裹了黑色方格线,直接删掉下划线不就行了

2、屋顶数字默认与左侧列的X相同,如果我需要左侧列有数字,左侧列空值,就需要写屋顶单元格与右侧单元格的组合代码。

本代码无法实现左右侧面空格的通用模板。

后续在研究……【教学类-06-12】20231202 0-9数字分合-房屋样式-下右空-升序

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

vue3请求代理proxy中pathRewrite失效

问题引入 在vue3配置请求代理proxy的时候pathRewrite失效。 有这样一个例子,作用是为了把所有以/api开头的请求代理到后端的路径和端口上,在vue.config.js配置文件中 设置了代理跨域和默认端口。但是重新运行之后发现端口是改了,但是路径仍然…

fl studio21.2最新汉化中文完整版网盘下载

fl studio 21中文版是Image-Line公司继20版本之后更新的水果音乐制作软件,很多用户不太理解,为什么新版本不叫fl studio 21或fl studio2024,非得直接跳到21.2版本,其实该版本是为了纪念该公司22周年,所以该版本也是推出…

认知觉醒(二)

认知觉醒(二) 内观自己,摆脱焦虑 第一章 大脑——一切问题的起源 第一节 大脑:重新认识你自己 我猜很多人并不真正了解自己,甚至从未了解过,所以才会对自身的各种问题困惑不已。这里我说的“自己”,特指自己的大…

自定义类型:结构体(自引用、内存对齐、位段(位域))

目录 一. 结构体类型的声明和定义 1.1结构体相关概念 1.11结构的声明 1.12成员列表 1.2定义结构体类型变量的方法 1.21先声明结构体类型再定义变量名 ​​​​1.22在声明类型的同时定义变量 1.23直接定义结构类型变量 二、结构体变量的创建、初始化​和访问 2.1结构体…

VS安装QT VS Tools编译无法通过

场景: 项目拷贝到虚拟机内部后,配置好相关环境后无法编译,安装QT VS Tools后依旧无法编译,查找资料网上说的是QT工具版本不一致导致的,但反复试了几个版本后依旧无法编译通过。错误信息如下: C:\Users\Ad…

【动态规划】LeetCode-64.最小路径和

🎈算法那些事专栏说明:这是一个记录刷题日常的专栏,每个文章标题前都会写明这道题使用的算法。专栏每日计划至少更新1道题目,在这立下Flag🚩 🏠个人主页:Jammingpro 📕专栏链接&…

第九节HarmonyOS 常用基础组件4-Button

一、Button Button组件主要用来响应点击操作,可以包含子组件。 示例代码: Entry Component struct Index {build() {Row() {Column() {Button(确定, { type: ButtonType.Capsule, stateEffect: true }).width(90%).height(40).fontSize(16).fontWeigh…

大数据技术之Flume(超级详细)

大数据技术之Flume(超级详细) 第1章 概述 1.1 Flume定义 Flume是Cloudera提供的一个高可用的,高可靠的,分布式的海量日志采集、聚合和传输的系统。Flume基于流式架构,灵活简单。 1.2 Flume组成架构 Flume组成架构如…

C# WPF上位机开发(计算器界面设计)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 c# wpf最大的优势就是开发业务软件比较快、效率比较高。一般来说,它的界面和逻辑部分可以同时开发。界面的部分用xaml编写即可&#xf…

深度学习——第03章 Python程序设计语言(3.1 Python语言基础)

无论是在机器学习还是深度学习中,Python已经成为主导性的编程语言。而且,现在许多主流的深度学习框架,例如PyTorch、TensorFlow也都是基于Python。本课程主要是围绕“理论实战”同时进行,所以本章将重点介绍深度学习中Python的必备…

解读Java虚拟机垃圾回收器:探究经典算法背后的奥秘

目录 一、GC分类与性能指标 (一)垃圾回收器分类 (二)性能指标 (三)不可能三角 二、不同的垃圾回收器概述 三、Serial回收器:串行回收 四、ParNew回收器:并行回收 五、Parall…

Nginx实现多虚拟主机配置

Nginx实现多虚拟主机配置 Nginx为什么要进行多虚拟主机配置呢?what? Nginx实现多虚拟主机配置的主要原因是,一个服务器可能会承载多个网站或应用程序,这些网站或应用程序需要使用不同的域名或IP地址来进行访问。如果只有一个虚拟…

SHAP(五):使用 XGBoost 进行人口普查收入分类

SHAP(五):使用 XGBoost 进行人口普查收入分类 本笔记本演示了如何使用 XGBoost 预测个人年收入超过 5 万美元的概率。 它使用标准 UCI 成人收入数据集。 要下载此笔记本的副本,请访问 github。 XGBoost 等梯度增强机方法对于具有…

Python----Pandas

目录 Series属性 DataFrame的属性 Pandas的CSV文件 Pandas数据处理 Pandas的主要数据结构是Series(一维数据)与DataFrame(二维数据) Series属性 Series的属性如下: 属性描述pandas.Series(data,index,dtype,nam…

模板初阶(2):函数模板的匹配原则,类模板的实例化

一、函数模板的匹配原则 int Add(const int& x, const int& y) {return x y; }template <class T> T Add(const T& x, const T& y) {return x y; }int main() {int a1 1, a2 2;Add(a1, a2);double d1 1.1, d2 2.2;Add(d1, d2);return 0; }一个非模…

ELK配置记录

1. filebeat.yml配置 启动命令&#xff1a; ./filebeat -e -c filebeat.yml # 输入 filebeat.inputs: - type: logenabled: truepaths:- /soft/log/base.*#跨行日志正则&#xff0c;从有时间的开始&#xff0c;到下一个时间之前结束multiline.pattern: ^\[[0-9]{4}-[0-9]{2}…

责任链设计模式

package com.jmj.pattern.responsibility;/*** 请假条类*/ public class LeaveRequest {//姓名private String name;//请假天数private int num;//请假内容private String content;public LeaveRequest(String name, int num, String content) {this.name name;this.num num;…

FL Studio21.2汉化永久中文语言包

FL Studio21.2这款软件在国内被广泛使用&#xff0c;因此又被称为"水果"。它提供音符编辑器&#xff0c;可以针对作曲者的要求编辑出不同音律的节奏&#xff0c;例如鼓、镲、锣、钢琴、笛、大提琴、筝、扬琴等等任何乐器的节奏律动。此外&#xff0c;它还提供了方便快…

使用极限网关助力 ES 集群无缝升级、迁移上/下云

在工作中大家可能会遇到以下这些场景&#xff1a; 自建 ES 集群需要平滑迁移到 XX 云&#xff1b;从 XX 云将 ES 集群迁移到自建机房&#xff1b;ES 集群进行跨版本升级&#xff0c;同时保留回退能力&#xff1b; 这些场景往往都还有个共同的需求&#xff1a;迁移过程要保证业…

【经验分享】DDNS配置--使用DDNS-GO

DDNS配置 DDNS&#xff08;Dynamic Domain Name Server&#xff0c;动态域名服务&#xff09;是将用户的动态IP地址映射到一个固定的域名解析服务上&#xff0c;用户每次连接网络的时候客户端程序就会通过信息传递把该主机的动态IP地址传送给位于服务商主机上的服务器程序&…