展示效果:
单张效果(印章信息只保留名字)
多张效果(每张都是不同的青花纹理)
打印效果:
背景需求:
茶杯上面的花纹都不一样,可以让孩子们欣赏更多的青花纹理,每张的印章名字也不同
设计难点
原始花边图案需要顺时针、逆时针、倒置、裁切、贴入相应的格子内
Word模板设置
1、竖版 页边距0。7
2、插入3*4表格
茶杯手柄的尺寸高度为1.7,宽度为1、8.24、1、10.24
文字对齐方式:
第一行顶部居中
图片模板
编号为01-33共33张青花纹理条
EXCEL信息设置-简体转繁体
代码设计:
'''
作者:阿夏
时间:2022年12月04日插入式纸盒(茶杯-青花瓷-30款花边))
'''
import xlwt
import xlrd
import os
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 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
# 图片旋转
# https://www.php.cn/python-tutorials-417020.html
#首先建好一个数据_ud文件夹
import PIL.Image as img
import os
# 逆时针90度
path_old ='C:/Users/jg2yXRZ/OneDrive/桌面/插入茶杯/花边/' #文件夹目录
# 旋转图片存储的位置
for d in range(0,3):
os.mkdir(r'C:\Users\jg2yXRZ\OneDrive\桌面\插入茶杯\花边{}'.format(d))
filelist=os.listdir(path_old)
total_num=len(filelist)# 总元素
# 逆时针90度
path_new = 'C:/Users/jg2yXRZ/OneDrive/桌面/插入茶杯/花边0/'
for i in range(1,total_num+1):
im=img.open(path_old+str('%02d'%i)+".png")
ng=im.transpose(img.ROTATE_90)#旋转90度角(逆时针90度)
ng.save(path_new+str('%02d'%i)+'.png')
# 顺时针90度
path_new = 'C:/Users/jg2yXRZ/OneDrive/桌面/插入茶杯/花边1/'
for i in range(1,total_num+1):
im=img.open(path_old+str('%02d'%i)+".png")
ng=im.transpose(img.ROTATE_270)#旋转90度角(顺时针90度)
ng.save(path_new+str('%02d'%i)+'.png')
# 逆时针180度
path_new = 'C:/Users/jg2yXRZ/OneDrive/桌面/插入茶杯/花边2/'
# print(total_num)
for i in range(1,total_num+1):
o='%02d'%i
im=img.open(path_old+str(o)+".png")
ng=im.transpose(img.ROTATE_180)#旋转90度角(逆时针90度)
ng.save(path_new+str(o)+'.png')
# 裁剪图片
# from PIL import Image
# import matplotlib.pyplot as plt
# img=Image.open('d:/ex.jpg') #打开图像
# plt.figure("beauty")
# plt.subplot(1,2,1), plt.title('origin')
# plt.imshow(img),plt.axis('off')
# box=(80,100,260,300)
# roi=img.crop(box)
# plt.subplot(1,2,2), plt.title('roi')
# plt.imshow(roi),plt.axis('off')
# plt.show()
# 从原图片中裁剪感兴趣区域(roi),裁剪区域由4-tuple决定,该tuple中信息为(left, upper, right, lower)。 Pillow左边系统的原点(0,0)为图片的左上角。坐标中的数字单位为像素点。
print('----------第1步:新建一个临时文件夹------------')
# 新建一个”装N份word和PDF“的文件夹
os.mkdir(r'C:\Users\jg2yXRZ\OneDrive\桌面\插入茶杯\零时Word')
wb= xlrd.open_workbook(r"C:\Users\jg2yXRZ\OneDrive\桌面\插入茶杯\大1班名字篆书.xlsx") #打开文件并返回一个工作蒲对象。open_workbook可以点进去看看函数里面的参数的含义之类的,很详细,英语不好的可以百度翻译,翻译出来的结果差不多。
sheet=wb.sheet_by_index(0) #通过索引的方式获取到某一个sheet,现在是获取的第一个sheet页,也可以通过sheet的名称进行获取,sheet_by_name('sheet名称')
# col1=sheet.col_values(0)# 学号
col2=sheet.col_values(2)# 名字
num=len(col2)-1 # 第一列去掉第一行s
# 填写印章(姓名)
name=[]
for i in range(1,len(col2)):
names='{}'.format (col2[i])
name.append(names) #
# print(name)
# print(len(name))
bg=['00', '01', '02'] # Word第一行三个表贴的图一样
for num in range(0,len(name)): # 一共32份
# 每页插入文字
doc = docx.Document(r"C:\Users\jg2yXRZ\OneDrive\桌面\插入茶杯\插入茶杯(模板).docx")
c=name[num]
table = doc.tables[0] # 一共有2个表格,在第1个表格里
run=table.cell(1,1).paragraphs[0].add_run(c) # 在单元格0,0(第1行第1列)输入国家名称
run.font.name = '隶书'#输入时默认华文彩云字体
run.font.size = Pt(60) #输入字体大小默认30号
run.font.color.rgb = RGBColor(79,81,120) #青花色
# paragraph.paragraph_format.line_spacing = Pt(180) #数字段间距
# paragraph.paragraph_format.line_spacing = 1
r = run._element
r.rPr.rFonts.set(qn('w:eastAsia'), '隶书')#将输入语句中的中文部分字体变为华文行楷
table.cell(1,1).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中
# 提取原始图片路径:插入三个格子
path=r'C:\Users\jg2yXRZ\OneDrive\桌面\插入茶杯\花边'
files= os.listdir(path) # 文件夹目录
# print(files)
lists=[] # 所有图片路径的集合
for f in files:
a='{}\{}'.format(path,f)
lists.append(a)
# 插入原始第1行3个横向
for t in range(0,len(bg[0:3])): # 02
pp=int(bg[t][0])
qq=int(bg[t][1])
k=lists[num] # 依次提取每一张花纹图案
# print(k)
run=doc.tables[0].cell(pp,qq).paragraphs[0].add_run() # 在第1个表格中第2个单元格内插入国旗
run.add_picture('{}'.format(k),width=Cm(6.3),height=Cm(1))
table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中
# 插入底部花纹
path2=r'C:\Users\jg2yXRZ\OneDrive\桌面\插入茶杯\花边2'
files2= os.listdir(path2) # 文件夹目录
# print(files1)
lists2=[] # 所有图片路径的集合
for f2 in files2:
a2='{}\{}'.format(path2,f2)
lists2.append(a2)
k2=lists2[num]
run=doc.tables[0].cell(3,1).paragraphs[0].add_run()
run.add_picture('{}'.format(k2),width=Cm(6.3),height=Cm(1))
table.cell(3,1).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中
# 插入左侧花纹 插入3,0格
path0=r'C:\Users\jg2yXRZ\OneDrive\桌面\插入茶杯\花边0'
files0= os.listdir(path0) # 文件夹目录
# print(files)
lists0=[] # 所有图片路径的集合
for f0 in files0:
a0='{}\{}'.format(path0,f0)
lists0.append(a0)
k0=lists0[num]
run=doc.tables[0].cell(3,0).paragraphs[0].add_run() #
run.add_picture('{}'.format(k0),width=Cm(1),height=Cm(6.2))
table.cell(3,0).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.LEFT #居中
# 左侧框底边
run=doc.tables[0].cell(3,0).paragraphs[0].add_run()
run.add_picture('{}'.format(k2),width=Cm(5.12),height=Cm(1))
table.cell(3,0).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.RIGHT #居中
# 右侧框底边
run=doc.tables[0].cell(3,2).paragraphs[0].add_run()
run.add_picture('{}'.format(k2),width=Cm(5.12),height=Cm(1))
table.cell(3,2).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.RIGHT #居中
# 插入右侧花纹
path1=r'C:\Users\jg2yXRZ\OneDrive\桌面\插入茶杯\花边1'
files1= os.listdir(path1) # 文件夹目录
# print(files1)
lists1=[] # 所有图片路径的集合
for f1 in files1:
a1='{}\{}'.format(path1,f1)
lists1.append(a1)
k1=lists1[num]
run=doc.tables[0].cell(3,2).paragraphs[0].add_run() # 在第1个表格中第2个单元格内插入国旗
run.add_picture('{}'.format(k1),width=Cm(1),height=Cm(6.3))
table.cell(3,2).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.RIGHT #居中
# 手柄表格插入图片
table = doc.tables[1] # 手柄表格插入图片
run=doc.tables[1].cell(0,1).paragraphs[0].add_run() # 在第1个表格中第2个单元格内插入国旗
run.add_picture('{}'.format(k),width=Cm(8.24),height=Cm(1.65))
table.cell(0,1).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中 #
doc.save(r"C:\Users\jg2yXRZ\OneDrive\桌面\插入茶杯\零时Word\{}.docx".format('%02d'%num))
from docx2pdf import convert
# docx 文件另存为PDF文件
inputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/插入茶杯/零时Word/{}.docx".format('%02d'%num)# 要转换的文件:已存在
outputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/插入茶杯/零时Word/{}.pdf".format('%02d'%num) # 要生成的文件:不存在
# 先创建 不存在的 文件
f1 = open(outputFile, 'w')
f1.close()
# 再转换往PDF中写入内容
convert(inputFile, outputFile)
# 多个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/桌面/插入茶杯/(打印合集)大班A整页插入茶杯2乘5加表格-4名字-({}人).pdf".format(num))
file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/插入茶杯/(打印合集)大班插入青花茶杯({}人).pdf".format(num+1))
file_merger.close()
# doc.Close()
# # print('----------第5步:删除临时文件夹------------')
import shutil
shutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/插入茶杯/零时Word') #递归删除文件夹,即:删除非空文件夹
for d in range(0,3):
shutil.rmtree(r'C:\Users\jg2yXRZ\OneDrive\桌面\插入茶杯\花边{}'.format(d))
重点说明:
教学过程:
时间:2022年12月16日15:00-15:30
班级:大1班
人数:5人(1-5号中有3位女孩在园,拿到自己名字的纸膜,另外两份给了两位能干的女孩。)
背景说明:
昨天我接到通知下周一正式成为中7班班主任(原班主任怀孕请假休养),再也没有机会带机动班(大1班、中3班),所以我想把前期设计的一些python纸类学具用掉。
几天前我想打印大一班1号的青花茶杯纸膜做个测试(是否能够按线条折出茶杯),因为没有设置好,变成打印了全部。紧急关闭打印机程序后,已经打印了5张(学号1-5号)。我想把这几张用掉。这几天混管阳性的老师幼儿及同住人越来越多,幼儿人数越来越少。
1-5号中有3位女孩在园,拿到自己名字的纸膜,另外两份给了两位能干的女孩。
1、剪边
折线
凹造型
黏贴手柄
创意水壶
写名字做记号
作品展示
感悟:
折痕线与实际折叠效果有差异(虚线能看到)纸膜折线需要适当调整位置,适应折叠厚度。