背景需求:
做过A4横版的25CM短尺,怎么能不做一份竖版的短尺呢
做一份竖版的直尺,测算后竖版可以做8把短尺
素材准备
word具体参数见
代码展示:
'''
目的:
1、4.0纸尺A4 8条 每条17CM 有图案
2、作者:阿夏
时间:2024年2月1日)
'''
import os
num=int(input('请输入几份,最大5份\n'))
# 做一份尺子的模板
jc=17
# 一行最多26
h=8
# 一行0-25 25-50
# 每份插入一个符号(以免搞错)
print('----------第0步:符号------------')
patho=['☆','□','○','◇','△','⊕','☼','☺','☏','◎','⊿','√', '×','☑','☹','☺','☼','♫','❀','❤','✉','✄','✈','♘','♕','♔','☀','☉','☋','☁','☂','☽','♤','♡','♢','♧','☆','□','○','◇']
print(len(patho))
# 36、这里只需要8的倍数,删除一个
# 做成五个五个一组
pic=[]
for w in range(int(len(patho)/h)):
pic.append(patho[w*h:w*h+h])
print(pic)
print('----------第1步:提取数字------------')
all=[]
for m in range(h):
for l in range(jc+1):
all.append(str(l))
list=[]
for n in range(int(len(all)/(jc+1))):
list.append(all[n*(jc+1):n*(jc+1)+(jc+1)])
print(list)
print(len(list))
# 130 26一条
bg1=[]
for x in range(1,2):
for y in range(1,(jc+1)*2,2): # 因为第一行和第二行是斜角错开的,所以格子要翻倍
# if '%03d'%y=='053':
# pass
# else:
bg1.append('{}{}'.format('%02d'%x,'%02d'%y))
print(bg1)
print(len(bg1))
# # ['0101', '0103', '0105', '0107', '0109', '0111', '0113', '0115', '0117', '0119', '0121', '0123', '0125', '0127', '0129', '0131', '0133', '0135', '0137', '0139', '0141', '0143', '0145', '0147', '0149']
# # 25
bg2=['0204']
# # # print('----------第2步:新建一个临时文件夹------------')
# # # # # 新建一个”装N份word和PDF“的文件夹
# os.mkdir
imagePath1=r'C:\Users\jg2yXRZ\OneDrive\桌面\尺子\零时Word'
if not os.path.exists(imagePath1): # 判断存放图片的文件夹是否存在
os.makedirs(imagePath1) # 若图片文件夹不存在就创建
print('----------第2步:制作尺子模板 ------------')
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
import random
import os,time
import docx
from docx import Document
from docx.shared import Inches,Cm,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
for nn in range(0,num): # 4
doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\尺子\尺子17.docx')
for b in range(h): # 共有2个表格
table = doc.tables[b] # 一共有2个表格
# 数字插入
for tt in range(len(bg1)): # 26个
pp=int(bg1[tt][0:2])
qq=int(bg1[tt][2:4])
# print(p)
k=str(list[b][tt]) # 每个坐标里面插入一个☉
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(14) #是否加粗
run.font.color.rgb = RGBColor(0,0,0) #数字小,颜色深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 #居中
# 图形插入
for tt2 in range(len(bg2)): # 26个
pp2=int(bg2[tt2][0:2])
qq2=int(bg2[tt2][2:4])
# print(p)
k2=str(pic[nn][b]) # 每个坐标里面插入一个☉
print(pp2,qq2,k2)
# 图案符号的字体、大小参数
run=table.cell(pp2,qq2).paragraphs[0].add_run(k2) # 在单元格0,0(第1行第1列)输入第0个图图案
run.font.name = '黑体'#输入时默认华文彩云字体
# run.font.size = Pt(46) #输入字体大小默认30号 换行(一页一份大卡片
run.font.size = Pt(35) #是否加粗
run.font.color.rgb = RGBColor(0,0,0) #数字小,颜色深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'%nn))
# time.sleep(1)
from docx2pdf import convert
# docx 文件另存为PDF文件
inputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/尺子/零时Word/{}.docx".format('%02d'%nn) # 要转换的文件:已存在
outputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/尺子/零时Word/{}.pdf".format('%02d'%nn) # 要生成的文件:不存在
# 先创建 不存在的 文件
f1 = open(outputFile, 'w')
f1.close()
# 再转换往PDF中写入内容
convert(inputFile, outputFile)
time.sleep(1)
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)
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/尺子/(打印合集)短尺4.0有图案17CM({}人共{}张).pdf".format(num*h,int(num)))
file_merger.close()
# doc.Close()
# print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/尺子/零时Word') #递归删除文件夹,即:删除非空文件夹o
终端输入:
这样只要打印5张铅画纸,开学了先用17CM短尺进行测量练习吧
2024年12月29日,
今天从仓库里找出这些铅画纸尺子。给中2班小朋友涂色用
选尺子,写学号