首页 > 其他分享 >【教学类-76-01】20240820书包01(图案最大化)

【教学类-76-01】20240820书包01(图案最大化)

时间:2024-08-21 20:23:56浏览次数:26  
标签:docx 01 20240820 76 import path folder os dst

背景需求

通义万相生成图片,把图案最大化的方法(切掉白边)

【教学类-75-01】20240817“通义万相图片最大化+透明png”的修图流程-CSDN博客文章浏览阅读1.6k次,点赞56次,收藏17次。【教学类-75-01】20240817“通义万相图片最大化+透明png”的修图流程https://blog.csdn.net/reasonsummer/article/details/141275880

前几天下载了一套“书包图片”,想把它做成一个对称书包学具

先整理素材


01原图(背景灰色)

02透明(先P图白色背景,在用Python将白色变成透明)本次没有用到透明图片

03 用PS+UIBOT将每张图片的背景变成白色

04手动PS修图,把背景上不要的黑点涂成白色、书包上的大眼睛涂成白色

05、直接把白色背景的图片切边(没有留10像素的白边)

图案的四个顶点卡在画边上

06把所有切边的书包图片统一成一样的大小 (最大宽度的图片的尺寸是906*897)

07把统一图做成垂直翻转的造型

翻转代码

'''
书包图片上下翻转
星火讯飞 阿夏
20240820
'''

import os
from PIL import Image

def flip_images(src_folder, dst_folder):
    if not os.path.exists(dst_folder):
        os.makedirs(dst_folder)

    for filename in os.listdir(src_folder):
        if filename.lower().endswith(('.png', '.jpg', '.jpeg')):
            src_path = os.path.join(src_folder, filename)
            dst_path = os.path.join(dst_folder, filename)

            with Image.open(src_path) as img:
                flipped_img = img.transpose(Image.FLIP_TOP_BOTTOM)
                flipped_img.save(dst_path)

path=r'C:\Users\jg2yXRZ\OneDrive\图片\20240816书包'
src_folder = path+r'\06统一图'
dst_folder = path+r'\07翻转图'
flip_images(src_folder, dst_folder)



模版的样式(2行1列,边框线隐藏,只有中间的虚线)

制作学具的代码

'''
书包两片 垂直堆成
星火讯飞 阿夏
20240820
'''



# print('----1、制作左右翻转图------')

import os
from PIL import Image

import os,time
import shutil
from docx import Document
from docx.shared import Cm
from PIL import Image
from PyPDF2 import PdfFileMerger, PdfFileReader

from PIL import Image, ImageDraw, ImageFont
import os,random

# def flip_images(src_folder, dst_folder):
#     if not os.path.exists(dst_folder):
#         os.makedirs(dst_folder)

#     for file in os.listdir(src_folder):
#         if file.lower().endswith(('.png', '.jpg', '.jpeg', '.gif', '.bmp')):
#             img = Image.open(os.path.join(src_folder, file))
#             flipped_img = img.transpose(Image.FLIP_LEFT_RIGHT)
#             flipped_img.save(os.path.join(dst_folder, file))
path=r'C:\Users\jg2yXRZ\OneDrive\图片\20240816书包'
src_folder = path+r'\06统一图'
dst_folder = path+r'\07翻转图'
os.makedirs(dst_folder,exist_ok=True)
# flip_images(src_folder, dst_folder)


print('----2、图片路径组合------')


# 获取文件夹下的所有图片文件
left_files = [os.path.join(src_folder, f) for f in os.listdir(src_folder) if f.endswith(('.jpg', '.jpeg', '.png'))]
right_files = [os.path.join(dst_folder, f) for f in os.listdir(dst_folder) if f.endswith(('.jpg', '.jpeg', '.png'))]


all=[]
for i in range(len(left_files)):
    all.append(left_files[i])
    all.append(right_files[i])
print(len(all))
#126*2=252


# 将图片拆成6个一组
grouped_files = [all[i:i + 2] for i in range(0, len(all), 2)]
print(len(grouped_files))
# 42张


print('----3、合并PDF------')


# 创建临时文件夹
new_folder = path+r'\零时文件夹'
os.makedirs(new_folder, exist_ok=True)

print('----3、插入docx,制作pdf------------')
# 处理每一组图片
for group_index, group in enumerate(grouped_files):
    # 创建新的Word文档
    doc = Document(path+r'\书包2.docx')
    # print(group)
    
    # 遍历每个单元格,并插入图片
    for cell_index, image_file in enumerate(group):
        # 计算图片长宽(单位:厘米)

        # 如果是空格,就跳过
        if not image_file:
            continue
    
        # 插入图片到单元格
        table = doc.tables[0]
        # cell = table.cell(int(cell_index / 1), cell_index % 1)
        cell = table.cell(int(cell_index / 2), cell_index % 2)
        # 如果第一行有2个格子,两个数字都写2
        cell_paragraph = cell.paragraphs[0]
        cell_paragraph.clear()
        run = cell_paragraph.add_run()
        # run.add_picture(image_file, width=Cm(19.51), height=Cm(14.11))
        run.add_picture(image_file, width=Cm(14.11), height=Cm(19.51))
        
    # 保存Word文档
    doc.save(os.path.join(new_folder, f'{group_index + 1:03d}.docx'))
    


# 将10个docx转为PDF
import os
from docx2pdf import convert
from PyPDF2 import PdfFileMerger

# pdf_output_path = path+fr'\\01书包配对横{int(len(left_files))}张共{int(len(left_files))}图.pdf'

pdf_output_path = path+fr'\\01书包配对竖{int(len(left_files))}张共{int(len(left_files))}图.pdf'

# 将所有DOCX文件转换为PDF
for docx_file in os.listdir(new_folder):
    if docx_file.endswith('.docx'):
        docx_path = os.path.join(new_folder, docx_file)
        convert(docx_path, docx_path.replace('.docx', '.pdf'))
        time.sleep(2)


# 合并零时文件里所有PDF文件
merger = PdfFileMerger()
for pdf_file in os.listdir(new_folder):
    if pdf_file.endswith('.pdf'):
        pdf_path = os.path.join(new_folder, pdf_file)
        merger.append(pdf_path)
time.sleep(2)

# 保存合并后的PDF文件
merger.write(pdf_output_path)
merger.close()


# 删除输出文件夹(删除零时文件夹和水平翻转图片文件夹)
shutil.rmtree(new_folder)
# shutil.rmtree(dst_folder)
time.sleep(2)

一张A4竖版,上下连在一起的书包(对称剪、涂色)、把书包的边缘黏起来,制作一个能装轻薄物品的书包——这样能让书包的口最大

还有一种是瘦一点的书包,把2行一列改成1行2列

开学后,问问孩子们喜欢哪一种,再决定打印几份

标签:docx,01,20240820,76,import,path,folder,os,dst
From: https://blog.csdn.net/reasonsummer/article/details/141369936

相关文章

  • Office 2010 详细安装教程
    Office2010引入了新的文件格式,改善了用户界面,并提供了64位版本,以提高性能和支持更大的数据集。此外,Office2010还包括了在线协作功能,允许用户从不同地点和设备上共同工作,以及新的SmartArt图形和背景移除工具等功能,以提高办公效率和文档的专业外观。 安装包:百度网盘请输入......
  • SSUD71-101 Understanding Buildings 241
    SSUD71-101Understanding Buildings241:Assignment2Topic: Assignment2:Group project requiring application ofconstructionprocesses/methods.Format:Part 1:Siteand HouseSummaryPart2: Detailed RoomConstructionSchedulePart3:Construction......
  • CF 2001 E2 solution (967 Div.2)
    CF2001E2由于对称,所以设\(heap[u]\)为两次确定堆,且第一次弹出的是\(u\),\(heap[u,v]\)是第一次\(u\),第二次\(v\)则答案就是\(\sumheap[u]=2^{n-1}·heap[x]\)其中\(x\)任意。不妨我们考虑第一次都是从第一个叶子弹出,那么对于其他不同的第二个弹出的点,根据对称性......
  • 信息学奥赛初赛天天练-71-NOIP2016普及组-基础题2-进制转换、二进制转八进制、八进制
    NOIP2016普及组基础题24以下不是CPU生产厂商的是()AIntelBAMDCMicrosoftDIBM8与二进制小数0.1相等的八进制数是()A0.8B0.4C0.2D0.19以下是32位机器和64位机器的区别是()A显示器不同B硬盘大小不同C寻址......
  • 关于DensiStak™ 板对板连接器:10169063-5002100LF、10169063-5602100LF、10169064-500
    系列概述该DensiStak™板对板连接器是高密度连接器,采用双梁接触系统,可确保可靠性能。该连接器采用11排设计(具有多达1034个引脚位置)和开放式引脚现场设计,可提高灵活性。DensiStak连接器具有高达16Gb/s的高速性能,符合PCIe®Gen4、以太网、USB、DP和MIPI协议。DensiStak板对板连......
  • (4-7-01)文生图大模型实操:基于深度学习的图文匹配系统(1)工具类
    4.7 跨模态配对实战:基于深度学习的图文匹配系统本项目旨在构建一个多模态学习系统,专注于处理图像和文本数据的配对任务,主要基于CUHK-PEDES数据集。本项目实现了多种深度学习模型,包括LSTM、MobileNetV1和ResNet,以分别处理文本和图像特征的提取与融合。通过这些模型的结合,系......
  • Docker快速入门 01 安装、部署环境
    1.简介和安装1.1简介Docker是一个应用打包、分发、部署的工具。打包:需要的环境变成一个“安装包”。分发:将“安装包”上传到云端,供他人获取。部署:将“安装包”下载下来后直接快速搭建运行环境。通俗讲就是轻量级的虚拟机,只虚拟需要的运行环境。1.2安装这里以Docker......
  • SBT30100VFCT-ASEMI无人机专用SBT30100VFCT
    编辑:llSBT30100VFCT-ASEMI无人机专用SBT30100VFCT型号:SBT30100VFCT品牌:ASEMI封装:TO-220F批号:最新最大平均正向电流(IF):30A最大循环峰值反向电压(VRRM):100V最大正向电压(VF):0.70V~0..90V工作温度:-65°C~175°C反向恢复时间:35ns芯片个数:2芯片尺寸:74mil引脚数量:3正向浪涌电流......
  • 多功能便携工具!VH501TC多类型传感器读数仪,助你完成频率、温度、电压和电流测量!
    多功能便携工具!VH501TC多类型传感器读数仪,助你完成频率、温度、电压和电流测量!VH501TC是一款专用的多类型传感器手持式读数仪,主要用于测量单弦式振弦传感器的读数,同时也可以辅助测量电压和电流传感器的数据。该设备内置了LoRA无线技术,可以与我公司的NLM系列产品配合使用,实现传感......