【教学类-06-13】20231202 0-9数字分合-房屋样式(二)-左空或者右空-升序-抽7题

2023-12-03 22:44

本文主要是介绍【教学类-06-13】20231202 0-9数字分合-房屋样式(二)-左空或者右空-升序-抽7题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作品展示:

背景需求:

【教学类-06-12】20231202 0-9数字分合-房屋样式(一)-下右空-升序-抽7题-CSDN博客文章浏览阅读102次。【教学类-06-12】20231202 0-9数字分合-房屋样式-下右空-升序https://blog.csdn.net/reasonsummer/article/details/134750697?spm=1001.2014.3001.5501前文提到了此代码只能做房屋分合的右侧列空

解决:

微调代码,将左侧列空和右侧列空放在一个代码里,可以选择。

WORD样式-无下划线

代码展示

20231204发现pdffilemerger停止使用了,需要改成PDFmerger

'''
2-9之间随机抽取7个数字-房屋分合题-合-空在左侧and空在右侧,房屋 合并改成PDFmerger
时间:2023年12月03日 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'))
zyk=int(input('输入数字,左空=1,右空=2)\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步 单元格制作-----------')# 屋顶总数的坐标,无论左列空还是右列空,都是0100,0102,0104
bgb1=[]
for l1 in range(1,2):  # 行for y1 in range(0,14,2):   # 列           s1='{}{}'.format('%02d'%l1,'%02d'%y1)       # 数字加空格bgb1.append(s1) 
print(bgb1)
# ['0100', '0102', '0104', '0106', '0108', '0110', '0112']
print(len(bgb1))
# 7
if zyk==2:    # 右列空
# 左侧数字的坐标(30、40)写在一起,bgb2=[]for y2 in range(0,14,2):  # 列 左是0,14,2 /  右是1,14,2   for l2 in range(3,13):   # 行   连续行 s2='{}{}'.format('%02d'%l2,'%02d'%y2)       # 数字加空格bgb2.append(s2) print(bgb2)# ['0003', '0004', '0005', '0006', '0007', '0008', '0009', '0010', '0011', '0012', '0203', '0204', '0205', '0206', '0207', '0208', '0209', '0210', '0211', '0212', '0403', '0404', '0405', '0406', '0407', '0408', '0409', '0410', '0411', '0412', '0603', '0604', '0605', '0606', '0607', '0608', '0609', '0610', '0611', '0612', '0803', '0804', '0805', '0806', '0807', '0808', '0809', '0810', '0811', '0812', '1003', '1004', '1005', '1006', '1007', '1008', '1009', '1010', '1011', '1012', '1203', '1204', '1205', '1206', '1207', '1208', '1209', '1210', '1211', '1212']print(len(bgb2))# 70
if zyk==1:# 左列空bgb2=[]for y2 in range(1,14,2):  # 列 左是0,14,2 /  右是1,14,2   for l2 in range(3,13):   # 行   连续行 s2='{}{}'.format('%02d'%l2,'%02d'%y2)       # 数字加空格bgb2.append(s2) print(bgb2)# ['0003', '0004', '0005', '0006', '0007', '0008', '0009', '0010', '0011', '0012', '0203', '0204', '0205', '0206', '0207', '0208', '0209', '0210', '0211', '0212', '0403', '0404', '0405', '0406', '0407', '0408', '0409', '0410', '0411', '0412', '0603', '0604', '0605', '0606', '0607', '0608', '0609', '0610', '0611', '0612', '0803', '0804', '0805', '0806', '0807', '0808', '0809', '0810', '0811', '0812', '1003', '1004', '1005', '1006', '1007', '1008', '1009', '1010', '1011', '1012', '1203', '1204', '1205', '1206', '1207', '1208', '1209', '1210', '1211', '1212']print(len(bgb2))# 屋顶坐标+左侧列坐标合并=11个格子一组
bg=[]
u=int(len(bgb2)/(tm)) #u=10个  tm-7
for q in range(int(tm)):    # q=0--7aa=bgb2[q*u:q*u+u]    # a提取前10个坐标aa.insert(0,bgb1[q])    # a的十个坐标前面再加一个屋顶坐标 一共11个坐标bg.append( aa)# 添加成为[['11个坐标'],['11个坐标'],['11个坐标']]d的样式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)# # # 第一行的班级和项目if zyk==2:    # 右列空title='{}-{}抽取{}题 房屋右空 升序'.format(sum1,sum2,tm)if zyk==1:    # 左列空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 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 zyk==2:# 右列空file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/分合题/(打印合集)01“+”(一页两份 ){}-{}之间分合屋顶抽{}题 右空({}人打印{}张).pdf" .format('%02d'%sum1,'%02d'%sum2,tm,num,int(num/2)))
if zyk==1:# 左列空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') #递归删除文件夹,即:删除非空文件夹

终端运行

(一)左列空

(二)右列空

重点说明:

1、确定屋顶数字坐标

2、确定左侧、右侧分列的单元格坐标

3、用insert方式在10个一组的左列右列单元格坐标前加上屋顶的坐标。

感悟:

除了append(),还可以看看有没有其他的列表元素组合方式,让代码长度缩短,更精炼。

这篇关于【教学类-06-13】20231202 0-9数字分合-房屋样式(二)-左空或者右空-升序-抽7题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/451151

相关文章

HTML5中下拉框<select>标签的属性和样式详解

《HTML5中下拉框<select>标签的属性和样式详解》在HTML5中,下拉框(select标签)作为表单的重要组成部分,为用户提供了一个从预定义选项中选择值的方式,本文将深入探讨select标签的... 在html5中,下拉框(<select>标签)作为表单的重要组成部分,为用户提供了一个从预定义选项中

前端 CSS 动态设置样式::class、:style 等技巧(推荐)

《前端CSS动态设置样式::class、:style等技巧(推荐)》:本文主要介绍了Vue.js中动态绑定类名和内联样式的两种方法:对象语法和数组语法,通过对象语法,可以根据条件动态切换类名或样式;通过数组语法,可以同时绑定多个类名或样式,此外,还可以结合计算属性来生成复杂的类名或样式对象,详细内容请阅读本文,希望能对你有所帮助...

Java数字转换工具类NumberUtil的使用

《Java数字转换工具类NumberUtil的使用》NumberUtil是一个功能强大的Java工具类,用于处理数字的各种操作,包括数值运算、格式化、随机数生成和数值判断,下面就来介绍一下Number... 目录一、NumberUtil类概述二、主要功能介绍1. 数值运算2. 格式化3. 数值判断4. 随机

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

usaco 1.2 Name That Number(数字字母转化)

巧妙的利用code[b[0]-'A'] 将字符ABC...Z转换为数字 需要注意的是重新开一个数组 c [ ] 存储字符串 应人为的在末尾附上 ‘ \ 0 ’ 详见代码: /*ID: who jayLANG: C++TASK: namenum*/#include<stdio.h>#include<string.h>int main(){FILE *fin = fopen (

建立升序链表

题目1181:遍历链表 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:2744 解决:1186 题目描述: 建立一个升序链表并遍历输出。 输入: 输入的每个案例中第一行包括1个整数:n(1<=n<=1000),接下来的一行包括n个整数。 输出: 可能有多组测试数据,对于每组数据, 将n个整数建立升序链表,之后遍历链表并输出。 样例输