python自动化操作:批量处理照片尺寸并输出到word文档中【第14篇—python-照片尺寸批量处理输出】

news2025/2/24 9:37:52

文章目录

  • 一.背景
  • 二.需求
  • 三.实现源码
    • 3.1 项目结构
    • 3.2 源码
    • 3.3 核心调节照片大小
  • 四.代码解释
  • 五.实现效果
  • 六.心得总结

一.背景

在当今数字化时代,照片处理和文档编辑是许多领域中不可或缺的任务。从个人创作到企业文档,人们经常需要快速而有效地处理大量照片,并将它们整合到文档中。Python作为一种强大而灵活的编程语言,为自动化这一过程提供了理想的平台。

这篇文章将探讨如何使用Python自动化操作,通过批量处理照片尺寸并将它们输出到Word文档中,实现高效而简便的工作流程。我们将使用PIL库(Python Imaging Library)来处理图像,并结合python-docx库创建和编辑Word文档。

背景中的任务涉及从一个指定文件夹中获取照片,将它们调整到预定的尺寸,并将结果整合到一个规范的Word文档中。这种自动化方法不仅提高了工作效率,还确保了一致性和标准化的输出。

通过掌握这些技能,读者将能够轻松适应各种场景,从个人博客到企业报告,都能够灵活地处理和呈现图像。这种自动化方法不仅适用于专业开发者,也为对Python和图像处理感兴趣的初学者提供了一个学习和实践的良好起点。

二.需求

当今社交媒体、博客和企业报告等领域中,图像在信息传递和内容呈现中扮演着至关重要的角色。随着图像数量的不断增加,人们需要一种快速而有效的方式来处理和整合这些图像,以便更好地展示信息。

本项目的背景是在处理大量照片并将其嵌入到文档中时,遇到了手动操作的不便和效率问题。手动调整每张照片的尺寸并逐一插入到文档中不仅费时且容易出错,特别是在需要频繁更新文档内容时。为了解决这个问题,我们决定创建一个自动化脚本,能够批量处理照片并将它们按照预定的尺寸嵌入到Word文档中。

该脚本的设计目标是提高处理效率,确保输出的文档具有一致的格式和布局,以满足不同场景下对图像处理和文档编辑的需求。通过采用Python编程语言和相关库,我们可以轻松实现这一目标,并且使得这一过程对于非专业用户也更加友好。

这个自动化脚本旨在为那些需要在文档中快速整合照片的用户提供便利。通过简化照片处理流程,用户可以专注于内容创作而不必过多关注繁琐的图像处理步骤。

三.实现源码

3.1 项目结构

在这里插入图片描述

3.2 源码

import os
from docx import Document
from docx.shared import Inches
from PIL import Image



# 调整照片大小的函数
def resize_image(image_path, target_width):
    img = Image.open(image_path)
    width_percent = (target_width / float(img.size[0]))
    height_size = int((float(img.size[1]) * float(width_percent)))
    resized_img = img.resize((target_width, height_size), Image.LANCZOS)
    return resized_img


# 存储照片的文件夹路径
photos_folder = "image"  # 将 "path_to_photos_folder" 替换为你存储照片的文件夹路径

# 创建一个新的Word文档
doc = Document()

# 依次处理照片
photo_count = 0
photos_per_page = 3
page_width = 6.5  # Word页面宽度,单位为Inches

for root, _, files in os.walk(photos_folder):
    for filename in files:
        if filename.lower().endswith(('.png', '.jpg', '.jpeg')):
            photo_count += 1
            photo_path = os.path.join(root, filename)

            # 调整照片大小
            target_width = int(page_width / photos_per_page * 1440)  # 1440是Word中1英寸对应的像素数
            resized_img = resize_image(photo_path, target_width)

            # 将照片添加到Word文档中
            if photo_count % photos_per_page == 1:
                # 添加新页面
                doc.add_page_break()

            # 添加照片到当前页面
            doc.add_picture(photo_path, width=Inches(page_width / photos_per_page))

            # 保存调整大小后的照片
            resized_photo_path = os.path.splitext(photo_path)[0] + "_resized.jpg"
            resized_img.save(resized_photo_path)

# 保存Word文档
doc.save("output.docx")

3.3 核心调节照片大小

调整照片大小的核心逻辑在resize_image函数中。以下是该函数的代码:

# 调整照片大小的函数
def resize_image(image_path, target_width):
    img = Image.open(image_path)
    width_percent = (target_width / float(img.size[0]))
    height_size = int((float(img.size[1]) * float(width_percent)))
    resized_img = img.resize((target_width, height_size), Image.LANCZOS)
    return resized_img

这个函数接受两个参数:image_path表示图像文件的路径,target_width表示目标宽度。在函数内部,它使用PIL库的Image.open打开图像,然后计算调整后的高度,最后使用img.resize进行调整,返回调整后的图像对象resized_img

在主循环中,通过调用resize_image函数将每张照片调整为指定的宽度:

# 调整照片大小
target_width = int(page_width / photos_per_page * 1440)  # 1440是Word中1英寸对应的像素数
resized_img = resize_image(photo_path, target_width)

这里,target_width被计算为使得每页显示的照片宽度满足指定的Word页面宽度。然后,调用resize_image(photo_path, target_width)将当前照片调整为目标宽度。

这个调整大小的过程确保了每张照片都符合指定的宽度,以适应Word文档的布局。

四.代码解释

你提供的代码主要用于批量处理照片,调整它们的大小,并将它们插入到一个Word文档中。下面是对代码的解释:

import os
from docx import Document
from docx.shared import Inches
from PIL import Image

# 调整照片大小的函数
def resize_image(image_path, target_width):
    img = Image.open(image_path)
    width_percent = (target_width / float(img.size[0]))
    height_size = int((float(img.size[1]) * float(width_percent)))
    resized_img = img.resize((target_width, height_size), Image.LANCZOS)
    return resized_img

# 存储照片的文件夹路径
photos_folder = "image"  # 将 "path_to_photos_folder" 替换为你存储照片的文件夹路径

# 创建一个新的Word文档
doc = Document()

# 依次处理照片
photo_count = 0
photos_per_page = 3
page_width = 6.5  # Word页面宽度,单位为Inches

for root, _, files in os.walk(photos_folder):
    for filename in files:
        if filename.lower().endswith(('.png', '.jpg', '.jpeg')):
            photo_count += 1
            photo_path = os.path.join(root, filename)

            # 调整照片大小
            target_width = int(page_width / photos_per_page * 1440)  # 1440是Word中1英寸对应的像素数
            resized_img = resize_image(photo_path, target_width)

            # 将照片添加到Word文档中
            if photo_count % photos_per_page == 1:
                # 添加新页面
                doc.add_page_break()

            # 添加照片到当前页面
            doc.add_picture(photo_path, width=Inches(page_width / photos_per_page))

            # 保存调整大小后的照片
            resized_photo_path = os.path.splitext(photo_path)[0] + "_resized.jpg"
            resized_img.save(resized_photo_path)

# 保存Word文档
doc.save("output.docx")

解释:

  1. resize_image函数:这个函数使用PIL库打开图像,然后按照给定的目标宽度调整图像的大小。它返回调整大小后的图像对象。

  2. 存储照片的文件夹路径:photos_folder变量包含了存储照片的文件夹路径,你需要将其替换为实际存储照片的文件夹路径。

  3. 创建一个新的Word文档:doc = Document()创建了一个空白的Word文档对象。

  4. 处理照片:通过遍历指定文件夹中的照片文件,对每张照片进行处理。

  5. resize_image函数用于调整照片大小,然后将照片插入到Word文档中。每插入photos_per_page张照片后,添加一个新页面。

  6. 调整大小后的照片保存在与原始照片相同的路径下,文件名以"_resized"结尾。

  7. 最终,Word文档保存为"output.docx"。

五.实现效果

image文件夹初始照片:
在这里插入图片描述
运行py文件:
在这里插入图片描述
image文件夹处理后照片:
在这里插入图片描述
word文档输出:
在这里插入图片描述

六.心得总结

这篇文章介绍了如何利用Python在数字化时代处理照片和文档编辑的需求中实现自动化操作。通过使用Python编程语言以及PIL库和python-docx库,作者设计了一个自动化脚本,能够批量处理照片并将它们按照预定的尺寸嵌入到Word文档中,提高了工作效率。

文章从项目的背景和需求出发,详细解释了为什么需要这样的自动化脚本以及它的应用场景。通过提供实现源码,读者可以了解到整个项目的结构和核心实现,包括调整照片大小的函数和主要的代码逻辑。

在实现源码的部分,文章通过解释核心调节照片大小的函数,展示了如何使用PIL库调整每张照片的大小,以适应Word文档的布局。此外,文章还对代码进行了解释,详细说明了每个部分的作用和实现细节。

最后,文章展示了代码的实际效果,通过图片展示了处理前后的照片对比和生成的Word文档。这样的实际效果展示使读者能够更直观地理解脚本的运行结果。

总的来说,这篇文章清晰地介绍了整个自动化项目的设计思路、实现细节和实际效果,为读者提供了一个学习和实践图像处理和文档编辑的良好起点。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1285949.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++检测字符串中有效的括号个数

匹配一个字符串buf中&#xff0c;连续包换运算符reg的次数&#xff1a; #include <iostream>//return 返回匹配的字符个数 //buf, 要检测的字符串 //reg, 包含的连续运算符 int GetMatchCount(std::string& buf, std::string& reg) {int nMatchCount 0;if (reg.…

android项目实战之使用框架 集成多图片、视频的上传

效果图 实现方式&#xff0c;本功能使用PictureSelector 第三方库 。作者项目地址&#xff1a;https://github.com/LuckSiege/PictureSelector 1. builder.gradle 增加 implementation io.github.lucksiege:pictureselector:v3.11.1implementation com.tbruyelle.rxpermissio…

DELL服务器ESXi 6.7平台配置网卡直通报错

报错信息&#xff1a; 内存设置无效: 内存预留 (sched.mem.min) 应该等于内存大小 尝试勾选内存配置&#xff1a;预留所有客户机内存 报错信息&#xff1a; 模块“DevicePowerOn”打开电源失败。 配置文件中缺少 pciPassthru1.id 条目。 无法启动虚拟机。 尝试&#xff1a…

基于Web和深度学习的辣椒检测产量预测系统

1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 研究背景与意义 辣椒是一种重要的经济作物&#xff0c;被广泛种植和消费。然而&#xff0c;辣椒的产量预测一直是农业生产中的重要问题。准确地预测辣椒的产量可以帮助农民合理安…

『时间之外』这个不得不思考的问题,还是要说一下

还记得当初自己为什么选择计算机&#xff1f; 当初你问我为什么选择计算机&#xff0c;我笑着回答&#xff1a;“因为我梦想成为神奇的码农&#xff01;我想像编织魔法一样编写程序&#xff0c;创造出炫酷的虚拟世界&#xff01;”谁知道&#xff0c;我刚入门的那天&#xff0…

鸿蒙开发—学习声明式UI

基本UI描述 ArkTS通过装饰器Component和Entry装饰struct关键字声明的数据结构&#xff0c;构成一个自定义组件。自定义组件中提供了一个build函数&#xff0c;开发者需在该函数内以链式调用的方式进行基本的UI描述&#xff0c;UI描述的方法请参考UI描述规范。 基本概念 stru…

(11_29)畅捷通的 Serverless 探索实践之路

作者&#xff1a;计缘 畅捷通介绍 畅捷通是中国领先的小微企业财税及业务云服务提供商&#xff0c;成立于2010年。畅捷通在2021年中国小微企业云财税市场份额排名第一&#xff0c;在产品前瞻性及行业全覆盖方面领跑市场&#xff0c;位居中国小微企业云财税厂商矩阵领军象限前…

医院运维 告警闪现后的故障排查

长期以来&#xff0c;医院信息化运维中存在着科室复杂、应用场景多、终端运维工作量大、软件系统兼容需求强等诸多痛点&#xff0c;且对技术设备的稳定性、连续性要求极高&#xff0c;在日常运维中&#xff0c;需要应对和解决这些问题来保障业务稳定、健康运行。 1、数据孤岛 …

mapbox实现框选要素

成果图 参考博客 https://blog.csdn.net/ScapeD/article/details/89158755 原理与源码 利用mapbox的queryRenderedFeatures方法可以获取范围内的要素&#xff0c;但是这个只能是点和矩形和范围内的全屏要素&#xff0c;并不支持多边形&#xff0c;所以实现这个的思路就是画完框…

合并一个文件夹下的多个txt文件,并对文本内容分列处理。

python 合并一个文件夹下的多个txt文件&#xff0c;并对文本内容分列。 原始文件&#xff1a; 最终结果&#xff1a; import pandas as pd import xlwt import pandas as pd from sqlalchemy import create_engine import pandas as pd import os import glob dirPath g…

深入浅出 Linux 中的 ARM IOMMU SMMU III

系统 I/O 设备驱动程序通常调用其特定子系统的接口为 DMA 分配内存&#xff0c;但最终会调到 DMA 子系统的 dma_alloc_coherent()/dma_alloc_attrs() 等接口。dma_alloc_coherent()/dma_alloc_attrs() 等接口通过 DMA IOMMU 的回调分配内存&#xff0c;并为经过 IOMMU 的 DMA 内…

十二、FreeRTOS之FreeRTOS任务相关API函数

本节需要掌握以下内容&#xff1a; 1&#xff0c;FreeRTOS任务相关API函数介绍&#xff08;熟悉&#xff09; 2&#xff0c;任务状态查询API函数实验&#xff08;掌握&#xff09; 3&#xff0c;任务时间统计API函数实验&#xff08;掌握&#xff09; 4&#xff0c;课堂总结…

视频分割方法:视频批量剪辑技巧,精准至秒高效分割

在视频编辑过程中&#xff0c;视频分割是一项基础但重要的步骤。对于许多初学者或非专业人士来说&#xff0c;视频分割可能是一项挑战。然而&#xff0c;随着技术的发展&#xff0c;现在有许多工具可以快速高效地进行视频分割。本文讲解云炫AI智剪如何一键分割视频&#xff0c;…

记住5个关键点,避免被身边人传染成胖子

在现代社会&#xff0c;肥胖已经成为一个全球性的疑难杂症。 越来越多的人为了减去身上的赘肉采取各种各样、五花八门的方法&#xff0c;但却发现收效甚微&#xff0c;总是抵挡不住各种各样的引诱&#xff0c;美食、游戏、聚餐、追剧&#xff0c;美食吃不到睡都睡不好&#xf…

【Unity动画】状态机中层的融合原理与用法详解

1. 状态机概念介绍 在Unity中&#xff0c;动画状态机&#xff08;Animator State Machine&#xff09;是一种强大的工具&#xff0c;用于控制游戏对象的动画行为。动画状态机由多个动画状态Animation和过渡条件Transition、层组成&#xff01;而层&#xff08;Layers&#xff…

抖音本地生活服务商申请入口在哪里?具体流程是怎样的?

不论是抖音的本地生活业务&#xff0c;还是后来的支付宝、视频号的本地生活业务&#xff0c;因为市场体量足够庞大&#xff0c;市场前景广阔&#xff0c;一直很受各大创业者的追捧。那么&#xff0c;如此火热的本地生活项目&#xff0c;想要申请成为服务商&#xff0c;具体的申…

五个轻量级免费 PDF 阅读器

便携式文档格式 (PDF) 是商业中最常用的文档类型之一。它们不仅是创建精心设计的文档的更通用的解决方案&#xff0c;而且还具有交互性和安全性。因此&#xff0c;对于寻求具有专业外观的文档的企业来说&#xff0c;PDF 是理所当然的选择。 当谈到查看这些文档时&#xff0c;大…

高等职业学校新媒体营销实训室解决方案

背景 随着数字化时代的来临&#xff0c;新媒体营销成为企业推广和品牌建设的关键手段。为了培养高职学生在新媒体领域的实际操作能力&#xff0c;建立一套全面、系统的实训室方案至关重要。 目标 搭建高职新媒体营销实训室&#xff0c;旨在培养学生的实际操作能力&#xff0…

微机原理11

一、单项选择题(本大题共15小题,每小题3分,共45分。在每小题给出的四个备选项中,选出一个正确的答案,请将选定的答案填涂在答题纸的相应位置上。) CPU 的数据总线提供&#xff08;&#xff09; A.数据信号流 B. 地址信号流 C.来自1O设备和存储器的响应信号 D.所有存储器和1/O设…

VirtualBox+Vagrant安装虚拟机

文章目录 一、下载Virtualbox和Vagrant1、下载2、安装 二、安装虚拟机1、新建目录D:\VirtualMachine2、执行vagrant init centos/7命令&#xff0c;就会在该目录下创建Vagrantfile文件3、执行vagrant up命令4、查看当前主机分给虚拟机的网关网段5、找到D:\VirtualMachine下的Va…