背景需求:
前文用UIBOT和Photoshop成功将袜子图片背景变成了纯白色
【教学类-74-01】袜子配对01(UIBOT图片背景填充白色)-CSDN博客文章浏览阅读1.7k次,点赞73次,收藏23次。【教学类-74-01】袜子配对01(UIBOT图片背景填充白色)https://blog.csdn.net/reasonsummer/article/details/140954279https://blog.csdn.net/reasonsummer/article/details/140954279
并制作了一套“左脚袜和右脚袜”的配对学具
【教学类-74-02】彩色袜子配对02--左右配对-CSDN博客文章浏览阅读338次,点赞9次,收藏3次。【教学类-74-02】彩色袜子配对02--左右配对https://blog.csdn.net/reasonsummer/article/details/141139239https://blog.csdn.net/reasonsummer/article/details/141139239
今天我想将彩色袜子与黑色影子进行配对
素材准备:
彩色袜子有126张
添加白背景后,图片已经压缩到2-300K了
WORD模版是一页六张(126除6=21*2=42张纸)
生成水平翻转图片
生成影子图
把所有不是255,255,255的颜色变成0,0,0黑色,因为背景修图都是白色255,255,255,所以彩色袜子区域就变成0,0,0黑色
代码展示
'''
彩色袜子,彩色和影子配对
星火讯飞 阿夏
20240812
'''
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 process_images(src_folder, dst_folder):
if not os.path.exists(dst_folder):
os.makedirs(dst_folder)
for root, dirs, files in os.walk(src_folder):
for file in files:
if file.lower().endswith(('.png', '.jpg', '.jpeg', '.gif', '.bmp')):
image_path = os.path.join(root, file)
img = Image.open(image_path)
pixels = img.load()
for i in range(img.size[0]):
for j in range(img.size[1]):
if pixels[i, j] != (255, 255, 255):
pixels[i, j] = (0, 0, 0)
img.save(os.path.join(dst_folder, file))
path=r'C:\Users\jg2yXRZ\OneDrive\桌面\20240806袜子配对\02袜子修图彩色白色'
src_folder = path+r'\01原图'
dst_folder = path+r'\03影子图'
os.makedirs(dst_folder,exist_ok=True)
process_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'))]
# 拆分成3左3右
left = [left_files[i:i +3] for i in range(0, len(left_files), 3)]
right = [right_files[i:i +3] for i in range(0, len(right_files), 3)]
all=[]
for i in range(len(left)):
for x in range(3): # 提取左图三张
all.append(left[i][x])
for x in range(3): # 提取右图三张
all.append(right[i][x])
print(len(all))
#126*2=252
# 将图片拆成6个一组
grouped_files = [all[i:i + 6] for i in range(0, len(all), 6)]
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'\彩色袜子配对.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 / 3), cell_index % 3)
# 如果第一行有2个格子,两个数字都写2
cell_paragraph = cell.paragraphs[0]
cell_paragraph.clear()
run = cell_paragraph.add_run()
run.add_picture(image_file, width=Cm(9.56), height=Cm(9.56))
# 保存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)/3)}张共{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)
作品展示:
生成时间5分钟,
都是上下一对袜子(彩色和它的影子)
拿来做小班益智区袜子配对