【教学类-21-02】20221210《青花茶杯-A4纸插入式纸盒-不同花纹》(大班主题《我是中国人-青花瓷》)

展示效果:

单张效果(印章信息只保留名字)

  多张效果(每张都是不同的青花纹理)

 

  打印效果:

 背景需求:

茶杯上面的花纹都不一样,可以让孩子们欣赏更多的青花纹理,每张的印章名字也不同

设计难点

原始花边图案需要顺时针、逆时针、倒置、裁切、贴入相应的格子内

 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、剪边

折线

 

 

 

 凹造型

 黏贴手柄

 

 

 创意水壶

 写名字做记号

 

作品展示 

 

 

 

 

 

 

 

 

感悟:

折痕线与实际折叠效果有差异(虚线能看到)纸膜折线需要适当调整位置,适应折叠厚度。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿夏reasonsummer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值