作品展示
背景需求:
骰子调整到第8版,把骰子图案作成一长条,便于切割裁剪。
【教学类-40-08】A4骰子纸模制作8.0(2.97CM嵌套骰子表格相连 一页7个 油墨打印A4铅画纸)-CSDN博客文章浏览阅读929次,点赞20次,收藏24次。【教学类-40-08】A4骰子纸模制作8.0(3CM嵌套骰子表格相连 一页7个 油墨打印A4铅画纸)https://blog.csdn.net/reasonsummer/article/details/135975259
很快发现幼儿直线裁剪都可以了(虽然很多孩子剪歪了)
但是折痕线的问题很大——铅画纸本身比较硬,幼儿自己折叠的线条不精确。容易歪斜。需要教师帮助修正位置,才能嵌套成功。
于是,我想到了“循环对折”的方法。
三次对折获得8个等分格子
第1次对折:2等分,
第2次对折:4等分、
第3次对折:8等分,
从8等分里选出5个格子,做一个正方形嵌套结构
素材准备:
代码展示
'''
目的:
1、骰子不同图案9.0 一页3个8格.3.47 厘米
2、作者:阿夏
时间:2024年3月28日)
'''
paths=r'C:\Users\jg2yXRZ\OneDrive\桌面\骰子不同图案'
import os
# num=int(input('生成多少份(28人)\n'))
print('----------第1步:提取图案------------')
#
# path=['▲','●','◆','■','★','✿','❀']
# '♠','♥','♦','♣',]
# 一页3个需要3的倍数36个
patho=['☆','□','○','◇','△','☉','⊕','☼','☺','☏','☽','◎','⊿','√', '☀','×','☑','☹','☺','☼','♫','☋','❀','❤','☁','☂','✉','✄','✈','♘','♕','♔','♤','♡','♢','♧']
# 需要3的倍数 36
print(len(patho))
# 点子总数 21
dz=1+2+3+4+5+6
# 把每个符号批量21次
pathall=[]
for t in range(len(patho)):
for v in range(dz):
pathall.append(patho[t])
print(pathall)
print(len(pathall))
# 756=36*21
# 行数6行
h=6
# 因为是21*3个一页,所以21乘以行数6除以2
cs=int(dz*h/2)
# 26分割 ['21个图形','21个图形']
path=[]
for t in range(int(len(pathall)/cs)):
path.append(pathall[t*cs:t*cs+cs])
print(path)
print(len(path))
# 12
print('----------第2步:新建一个临时文件夹------------')
# 新建一个”装N份word和PDF“的文件夹
imagePath=paths+r'\零时Word'
if not os.path.exists(imagePath): # 判断存放图片的文件夹是否存在
os.makedirs(imagePath) # 若图片文件夹不存在就创建
print('----------第3步:遍历输入每一种图案 ------------')
import docx
from docx.oxml.ns import qn
import random
import os,time
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
# # # 需要复制的倍数 第一个格子2个点,第2个格子1个点,第3个格子3个点
bg=[]
for x in range(0,h,2):
for y in range(0,4):
bg.append('{}{}'.format('%02d'%x,'%02d'%y))
for y in [1,3]:
bg.append('{}{}'.format('%02d'%(x+1),'%02d'%y))
print(bg)
print(len(bg))
# ['0000', '0001', '0002', '0003', '0101', '0103', '0200', '0201', '0202', '0203', '0301', '0303', '0400', '0401', '0402', '0403', '0501', '0503']
# 18
# 坐标
s=[]
sss=[1,2,6,5,3,4]
for ww in range(int(h/2)):
for ss in sss:
s.append(str(ss))
print(s)
print(len(s))
# 42
bg1=[]
for tt in range(len(s)):
hh=int(s[tt]) # 第一个数字1
print(hh)
for kk in range(hh): # 数字出现几次1次、2次、6次
jj=bg[tt] # bg的第一个坐标‘01’
bg1.append(jj)
print(bg1)
# ['01', '02', '02', '03', '03', '03', '03', '03', '03', '04', '04', '04', '04', '04', '12', '12', '12', '12', '12', '12', '14', '14', '14', '14']
for nn in range(0,len(path)): # 4
doc = Document(paths+r'\骰子嵌套9.0(3个2嵌套8格).docx')
# for b in range(h): # 共有2个表格
table = doc.tables[0] # 一共有2个表格
# 插入图形
for tt in range(len(bg1)): # 26个
pp=int(bg1[tt][0:2])
qq=int(bg1[tt][2:4])
# print(p)
k=path[nn][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(22) #是否加粗
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'path\零时Word\{}.docx'.format('%02d'%nn))
doc.save(imagePath+r'\{}.docx'.format('%02d'%nn))
from docx2pdf import convert
# docx 文件另存为PDF文件
inputFile = imagePath+r'\{}.docx'.format('%02d'%nn) # 要转换的文件:已存在
outputFile = imagePath+r'\{}.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 = imagePath
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(paths+r"\(打印合集)骰子横版9.0 A4 一页3个对折({}张共{}人).pdf".format(int(len(patho)/3),len(patho)))
file_merger.close()
# doc.Close()
# print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree(imagePath) #递归删除文件夹,即:删除非空文件夹