前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >python3 图片横向合并

python3 图片横向合并

作者头像
py3study
发布2020-01-02 17:54:03
5670
发布2020-01-02 17:54:03
举报
文章被收录于专栏:python3python3

安装必要库

代码语言:javascript
复制
pip install Pillow

代码

代码语言:javascript
复制
import os
import glob
import time
from sys import argv
from PIL import Image

# 多少张图片合成一张
merge_count = 2
merge_queue = []
min_width = 9999999
min_height = 99999999

if len(argv) <= 1:
    exit()

if not os.path.exists("output"):
    os.makedirs("output")

for _file in glob.glob(os.path.join(argv[1], "*.jpg")):
    img = Image.open(_file)
    if img.width > img.height:
        continue
    min_width = min(min_width, img.width)
    min_height = min(min_height, img.height)
    if len(merge_queue)+1 == merge_count:
        # merge image
        target = Image.new('RGB', (min_width*merge_count*merge_count, min_height))
        if abs(img.height - min_height) > 100:
            img = img.resize((int((img.width / img.height) * min_height), min_height))
        target.paste(img, (0,0))
        _tmpWidth = img.width
        for _tmpFile in merge_queue:
            _tmpImage = Image.open(_tmpFile)
            if abs(_tmpImage.height - min_height) > 100:
                _tmpImage = _tmpImage.resize((int((_tmpImage.width / _tmpImage.height) * min_height), min_height))
            target.paste(_tmpImage, (_tmpWidth, 0))
            _tmpWidth += _tmpImage.width
            _tmpImage.close()
        target = target.crop((0, 0, _tmpWidth, min_height))
        target.save("output/%d.jpg" % int(time.time()*1000))
        
        # reset count
        merge_queue = []
        min_width = 999999
        min_height = 999999
    else:
        merge_queue.append(img.filename)
    img.close()
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-10-16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装必要库
  • 代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档