【教学类-53-01】20240918自助餐餐盘

背景需求

最近忙着考计算机二级Python,没时间设计学具。

今天打印一套数感训练,中2班孩子找自己的学号,学习效果还不错。

【教学类-56-04】数感训练——数字04(中2班寻找自己的学号数字,1号-29号,出现5-10\10-15\15-20次)-CSDN博客文章浏览阅读954次,点赞22次,收藏5次。【教学类-56-04】数感训练——数字04(中2班寻找自己的学号数字,1号-29号,出现5-10\10-15\15-20次)https://blog.csdn.net/reasonsummer/article/details/141872632再接再厉,从以前下载的图片里找点做学具。给孩子们玩数学

挑了半天,选了一个“盘子花边”

“盘子白”说明已经用UIBOT和PS修图了

把盘子白的图片复制到01原图里

用以下代码把图片去掉白边,做成统一大小尺寸(有白色背景)

'''
去边后白色地方变成透明色
星火讯飞、阿夏
20240817
'''



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

path=r'C:\Users\jg2yXRZ\OneDrive\桌面\20240713盘子白'

# 留一点白边
white_edge=0
# C:\Users\jg2yXRZ\OneDrive\图片\20240817饮料甜甜圈\甜甜圈白色
import os
from PIL import Image

def find_non_white_pixel(image):
    width, height = image.size
    left, right, top, bottom = width, 0, height, 0

    for y in range(height):
        for x in range(width):
            r, g, b = image.getpixel((x, y))
            if r != 255 or g != 255 or b != 255:
                if x < left:
                    left = x
                if x > right:
                    right = x
                if y < top:
                    top = y
                if y > bottom:
                    bottom = y

    return left, right, top, bottom

def crop_image(image, left, right, top, bottom):
    return image.crop((left-white_edge, top-white_edge, right + white_edge, bottom + white_edge))



folder_path = path+r'\01原图'
output_folder = path+r'\02切边图'
os.makedirs(output_folder, exist_ok=True)


for file_name in os.listdir(folder_path):
    if file_name.endswith(".jpg") or file_name.endswith(".png"):
        input_path = os.path.join(folder_path, file_name)
        image = Image.open(input_path)
        left, right, top, bottom = find_non_white_pixel(image)
        cropped_image = crop_image(image, left, right, top, bottom)
        output_path = os.path.join(output_folder, file_name)
        cropped_image.save(output_path)



'''
去边后白色地方变成透明色,透明图片统一大小
星火讯飞、阿夏
20240817
'''      

print('----2、图片放大成为1024*1024------')
import os
from PIL import Image

# path=r'C:\Users\jg2yXRZ\OneDrive\图片\20240817饮料圆形'
# input_folder = path+r'\圆形切边图'
# output_folder = path+r'\圆形切边图透明'


# input_folder = path+r'\05切边图'
output_folder =path+r'\02切边图'
# output_folder = path+r'\04透明图'
newput_folder =path+r'\03统一图'
os.makedirs(newput_folder,exist_ok=True)

# 提取最大宽度的那张图片的尺寸
def get_max_width_and_height(fold_path):
    max_width = 0
    max_height = 0

    for file_name in os.listdir(fold_path):
        if file_name.endswith(".png") or file_name.endswith(".jpg") or file_name.endswith(".jpeg"):
            file_path = os.path.join(fold_path, file_name)
            img = Image.open(file_path)
            width, height = img.size
            if width > max_width:
                max_width = width
                max_height = height

    return max_width, max_height

fold_path = output_folder
max_width, max_height = get_max_width_and_height(fold_path)
print("最大宽度:", max_width)
print("最大高度:", max_height)

# 最大宽度: 724
# 最大高度: 869

# # 自定义长宽
# max_width=622
# max_height=877

# 统一所有图片大小
def resize_image(image_path, output_folder, new_image_name):
    img = Image.open(image_path)
    new_img = img.resize((max_width,max_height))
    new_img.save(os.path.join(output_folder, new_image_name))






for file in os.listdir(output_folder):
    if file.endswith('.png'):
        input_image_path = os.path.join(output_folder, file)
        new_image_name = f"{file[:-4]}.png"
        resize_image(input_image_path, newput_folder, new_image_name)


'''
图片上下翻转
'''

统一大小图里1023*1013

然后筛选图片,保留一些有边框图案的。

无边框

保留一些有边框图案的。

修图放在统一图的01文件夹里

用代码制作盘子上数字。

制作WORD模版

食物图片来源——WORD自带图表的svg矢量图

因为是撕贴,图案不需要很精美,只要简笔画轮廓即可,所有svg图片都变成黑边线白色填充的样式

最后只需要把不同的盘子(不同数字)放入第一个单元格即可。

'''
制作花边盘子,向内黏贴食物
星火讯飞 阿夏
2024年9月18日
'''

# 前期已经把盘子花边图切掉白边,变成统一大小
print('-----在盘子的上部写上数字----------')

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

def add_random_number_to_image(image_path, output_path):
    # 打开图片
    image = Image.open(image_path)
    width, height = image.size

    # 创建一个画布对象
    draw = ImageDraw.Draw(image)

    # 设置字体和大小
    font = ImageFont.truetype(r"C:\Windows\Fonts\ariblk.ttf", 100)

    # 生成随机数字
    random_number = random.randint(8, 10)

    # 计算数字的位置
    text_width, text_height = draw.textsize(str(random_number), font=font)
    x = (width - text_width) / 2
    y = (height - text_height) / 2

    # 在图片中间添加数字
    draw.text((x, y), str(random_number), font=font, fill=(0,0,0))

    # 保存图片
    image.save(output_path)

# # 遍历文件夹下的所有图片
path=r'C:\Users\jg2yXRZ\OneDrive\桌面\20240713盘子白'
folder_path = r'C:\Users\jg2yXRZ\OneDrive\桌面\20240713盘子白\03统一图\01挑选有花纹'
new_path = r'C:\Users\jg2yXRZ\OneDrive\桌面\20240713盘子白\04数字图'
os.makedirs(new_path,exist_ok=True)
for file_name in os.listdir(folder_path):
    if file_name.endswith(".jpg") or file_name.endswith(".png"):
        image_path = os.path.join(folder_path, file_name)
        output_path = os.path.join(new_path, file_name)
        add_random_number_to_image(image_path, output_path)


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

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
# 获取文件夹下的所有图片文件
all = [os.path.join(new_path, f) for f in os.listdir(new_path) if f.endswith(('.jpg', '.jpeg', '.png'))]

# 将图片拆成6个一组
grouped_files = [all[i:i + 1] for i in range(0, len(all), 1)]
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 / 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(19.51), 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(all))}张共{int(len(all))}图.pdf'

pdf_output_path = path+fr'\\01自助餐盘子{int(len(all))}张共{int(len(all))}图.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)

应该还是需要分类的(主食、水果、饮料、糖果)。暂时先这样,明天我想测试虚线刀是否管用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

阿夏reasonsummer

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

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

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

打赏作者

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

抵扣说明:

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

余额充值