【教学类-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,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'))
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:passQ =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行)是“/\”的符号,不要写入,跳过passelse:   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)):   #多少份  # 新建worddoc = 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题,数字就是4sl.append(f)print('提取7题每题里面数量{}'.format(sl))# 7题,每一题里面包含的数量 做少1题=0,最多10题=9# [10, 4, 7, 8, 9, 3, 1]# 提取随机抽数后的每题的等量坐标格子bgall=[]# 提取等量的坐标# 屋顶数量=数量-1for s in range(len(sl)):     # 7个for h in bg[s][:int(sl[s]+1)]:bgall.append(h)    # 添加全部坐标列表bg的第一组列表里面所有题目的0-X个坐标,因为包含了屋顶坐标,所以坐标组还要加1bgall.insert(0,d)        # 在0第一个位置插入标题的坐标print('提取坐标总量{}'.format(bgall))print(len(bgall))# 提取要输入格子的题目数字 一个总数 X个01234K=[]# 屋顶数量=数量-1for u in range(len(sl)):     # 7个# u.append(int(sl-1))   # 屋顶写入的数字K.append(str(sl[u]-1))   # 写入屋顶总数,需要减去1for 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-255run.font.color.rgb = RGBColor(100,100,100) #数字小,颜色深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.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数字分合-房屋样式-下右空-升序

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

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

相关文章

Postman Post请求上传文件

Postman Post请求上传文件 一、选择post请求方式,输入请求地址 二、填写Headers Key:Content-Type Value:multipart/form-data [{"key":"Content-Type","value":"multipart/form-data","de…

sourceTree的下载和安装

sourceTree的下载和安装 一、概述 SourceTree 是一款免费的 Git 和 Hg 客户端管理工具,支持 Git 项目的创建、克隆、提交、push、pull 和合并等操作。它拥有一个精美简洁的界面,大大简化了开发者与代码库之间的 Git 操作方式,这对于不熟悉 …

ChatGPT一周年,奥特曼官宣 OpenAI 新动作!

大家好,我是二狗。 今天是11月30日,一转眼,ChatGPT 发布已经一周年了! 而就在刚刚,ChatGPT一周年之际。 OpenAI 正式宣布Sam Altman回归重任CEO, Mira Murati 重任CTO,Greg Brockman重任总裁,O…

MySQL的时间与日期函数

1、日期格式 DATE_FORMAT("20231128", %Y-%m-%d) -- 2023-11-28 DATE_FORMAT("2023-11-28", %Y-%m-%d) -- 2023-11-28 DATE_FORMAT(2023-11-28 08:47:23, %H:%i:%s) -- 08:47:23 (24小时制) DATE_FORMAT(2023-11-28 08:47:23, %h:%i:%s) -- 08:47:23(12小…

可视化开源编辑器Swagger Editor本地部署并实现远程访问管理编辑文档

最近,我发现了一个超级强大的人工智能学习网站。它以通俗易懂的方式呈现复杂的概念,而且内容风趣幽默。我觉得它对大家可能会有所帮助,所以我在此分享。点击这里跳转到网站。 文章目录 Swagger Editor本地接口文档公网远程访问1. 部署Swagge…

Stable Diffusion AI绘画系列【10】:AI眼中的美丽清晨

《博主简介》 小伙伴们好,我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~ 👍感谢小伙伴们点赞、关注! 《------往期经典推…

前端开发新趋势:Web3、区块链与虚拟现实

文章目录 Web3:下一代互联网区块链技术去中心化应用程序(DApps) 区块链:重塑数字世界数字钱包NFT(非同质化代币) 虚拟现实:沉浸式体验WebVR和WebXR三维图形 新挑战与机会性能与复杂性安全性创新…

分享82个节日PPT,总有一款适合您

分享82个节日PPT,总有一款适合您 82个节日PPT下载链接:https://pan.baidu.com/s/1boDTl3PiHFXLJ890CoUfJA?pwd8888 提取码:8888 Python采集代码下载链接:采集代码.zip - 蓝奏云 学习知识费力气,收集整理更不易。…

jvm基本概念,运行的原理,架构图

文章目录 JVM(1) 基本概念:(2)运行过程 今天来和大家聊聊jvm, JVM (1) 基本概念: JVM 是可运行Java代码的假想计算机,包括一套字节码指令集、一组寄存器、一个栈一个垃圾回收,堆 和 一个存储方法域。JVM 是运行在操作…

使用 kubeadm 部署 Kubernetes 集群(三)kubeadm 初始化 k8s 证书过期解决方案

一、延长k8s证书时间 查看 apiserver 证书有效时间:默认是一年的有效期 [rootxuegod63 ~]# openssl x509 -in /etc/kubernetes/pki/apiserver.crt -noout -text |grep Not 延长证书过期时间 1.把 update-kubeadm-cert.sh 文件上传到 xuegod63 节点 vim update-…

安卓小程序与编译抓包

APK小程序渗透测试 查找bp的证书 在浏览器中打开bp代理,然后在网页中搜索hppps://burp 点击高级——接受风险并继续 拿到证书 将浏览器信任证书 打开设置 搜索证书——查看证书 点击导入——导入证书 证书验证成功后,访问网页(吾爱破解&a…

远程访问与设备重定向USB for Remote Desktop 官网

FabulaTech - USB over Network, USB for Remote Desktop, virtual COM ports FabulaTech.com - Downloads 另个软件-USB for Remote Desktop | 下载 USB over RDP app 用于远程桌面的 USB 在远程 Windows 会话中访问本地 USB 设备。 适用于 Windows 和 Linux 远程桌面。 下载…