在Python中,使用Pillow(PIL的更新分支)库来合并两张图片成一张上下结构的图片

在Python中,你可以使用Pillow(PIL的更新分支)库来合并两张图片成一张上下结构的图片。以下是一个简单的步骤和代码示例,展示如何做到这一点。

首先,确保你已经安装了Pillow库。如果还没有安装,可以通过pip安装:

bash 复制代码
pip install Pillow

然后,你可以使用以下代码来合并两张图片:

python 复制代码
from PIL import Image

def merge_images_vertically(image_path1, image_path2, output_path):
    # 打开两张图片
    image1 = Image.open(image_path1)
    image2 = Image.open(image_path2)
    
    # 确保两张图片具有相同的宽度,否则可能需要调整
    if image1.width != image2.width:
        # 这里简单处理,以第一张图片的宽度为准调整第二张图片的宽度
        # 注意:这可能会导致第二张图片被拉伸或压缩
        image2 = image2.resize((image1.width, int(image2.height * (image1.width / image2.width))))
        
    # 创建一个新的图片,大小为两张图片的高度之和,宽度与第一张图片相同
    result_width = image1.width
    result_height = image1.height + image2.height
    result_image = Image.new('RGB', (result_width, result_height))
    
    # 将第一张图片粘贴到新图片的顶部
    result_image.paste(image1, (0, 0))
    
    # 将第二张图片粘贴到新图片的底部(注意垂直偏移量)
    result_image.paste(image2, (0, image1.height))
    
    # 保存结果图片
    result_image.save(output_path)

# 示例用法
merge_images_vertically('path/to/your/image1.jpg', 'path/to/your/image2.jpg', 'path/to/your/merged_image.jpg')

请注意,这段代码假设了两张图片将被简单地垂直堆叠。如果两张图片的宽度不同,你可能需要决定如何处理这种差异(例如,调整第二张图片的宽度以匹配第一张图片的宽度,但这可能会导致图片的宽高比失真)。

在上面的代码中,我通过调整第二张图片的宽度来确保两张图片宽度相同,但这可能不是最佳方法,因为它可能会改变图片的宽高比。根据你的具体需求,你可能需要采取不同的策略,比如裁剪、填充空白区域等。

此外,请确保将image_path1image_path2output_path替换为你自己的图片路径和输出路径。

相关推荐
码路飞34 分钟前
FastMCP 实战:一个 .py 文件,给 Claude Code 装上 3 个超实用工具
python·ai编程·mcp
小猪努力学前端40 分钟前
基于PixiJS的试玩广告开发-续篇
前端·javascript·游戏
bluceli1 小时前
前端构建工具深度解析:从Webpack到Vite的演进之路
前端
wuhen_n1 小时前
v-model 的进阶用法:搞定复杂的父子组件数据通信
前端·javascript·vue.js
wuhen_n1 小时前
TypeScript 深度加持:让你的组合式函数拥有“钢筋铁骨”
前端·javascript·vue.js
滕青山1 小时前
基于 ZXing 的 Vue 在线二维码扫描器实现
前端·javascript·vue.js
Kayshen1 小时前
我在设计工具里实现了一个 Agent Team:多智能体协作生成 UI 的实战经验
前端·aigc·agent
swipe2 小时前
深入理解 JavaScript 中的 this 绑定机制:从原理到实战
前端·javascript·面试
Json_Lee2 小时前
2026 年了,多 Agent 编码该怎么选?agent-team vs Claude Agent Teams vs Claude Squad vs Met
前端·后端·vibecoding
Novlan12 小时前
Stepper 小数输入精度丢失 Bug 修复
前端