最近在写一篇卷积神经网络的论文,有好多实验结果需要整理,本来是用美图秀秀进行图像的拼接,但是发现重复操作太多,而且拼接效果不好,想到用python写个脚本实现,看一个简单的例子:
横向拼接
首先我需要将同一张图片的变形拼接为一行,代码如下:
import os from PIL import Image UNIT_SIZE = 229 # 单个图像的大小为229*229 TARGET_WIDTH = 6 * UNIT_SIZE # 拼接完后的横向长度为6*229 path = "C:/Users/zm/Desktop/FinalResult/Other-Reconstruction/2" images = [] # 先存储所有的图像的名称 for root, dirs, files in os.walk(path): for f in files : images.append(f) for i in range(len(images)/6): # 6个图像为一组 imagefile = [] j = 0 for j in range(6): imagefile.append(Image.open(path+'/'+images[i*6+j])) target = Image.new('RGB', (TARGET_WIDTH, UNIT_SIZE)) left = 0 right = UNIT_SIZE for image in imagefile: target.paste(image, (left, 0, right, UNIT_SIZE))# 将image复制到target的指定位置中 left += UNIT_SIZE # left是左上角的横坐标,依次递增 right += UNIT_SIZE # right是右下的横坐标,依次递增 quality_value = 100 # quality来指定生成图片的质量,范围是0~100 target.save(path+'/result/'+os.path.splitext(images[i*6+j])[0]+'.jpg', quality = quality_value) imagefile = []
纵向拼接
将每种类型的图片拼接为一行六个的图片后再将这些图片纵向拼接在一起,总共3种图像,那么有3行
import os from PIL import Image UNIT_SIZE = 229 # 图像的高 TARGET_WIDTH = 6 * UNIT_SIZE # 一行有6个图像,那么是6*229那么宽 path = "C:/Users/zm/Desktop/FinalResult/Other-Reconstruction/2/result" imagefile = [] for root, dirs, files in os.walk(path): for f in files : imagefile.append(Image.open(path+'/'+f)) target = Image.new('RGB', (TARGET_WIDTH, UNIT_SIZE*3)) # 最终拼接的图像的大小为(229*3) * (229*6) left = 0 right = UNIT_SIZE for image in imagefile: target.paste(image, (0, left, TARGET_WIDTH, right)) left += UNIT_SIZE # 从上往下拼接,左上角的纵坐标递增 right += UNIT_SIZE #左下角的纵坐标也递增 quality_value = 100 target.save(path+'/result.jpg', quality = quality_value)
同时横向纵向拼接
今天需要处理的图片如下:左边是图片所在的文件夹,每个文件夹的图片如→_→右边所示,需要拼接为2*5的图片。
写的脚本如下:
import os from PIL import Image UNIT_SIZE = 229 # the size of image def pinjie(images,num): target = Image.new('RGB', (UNIT_SIZE*5, UNIT_SIZE*2)) # result is 2*5 leftone = 0 lefttwo = 0 rightone = UNIT_SIZE righttwo = UNIT_SIZE for i in range(len(images)): if(i%2==0): target.paste(images[i], (leftone, 0, rightone, UNIT_SIZE)) leftone += UNIT_SIZE #第一行左上角右移 rightone += UNIT_SIZE #右下角右移 else: target.paste(images[i], (lefttwo, UNIT_SIZE, righttwo, UNIT_SIZE*2)) lefttwo += UNIT_SIZE #第二行左上角右移 righttwo += UNIT_SIZE #右下角右移 quality_value = 100 target.save(path+dirlist[num]+'.jpg', quality = quality_value) path = "C:/Users/laojbdao/Desktop/FinalResult/result4/different_distribution/" dirlist = [] # all dir name for root, dirs, files in os.walk(path): for dir in dirs : dirlist.append(dir) num = 0 for dir in dirlist: images = [] # images in each folder for root, dirs, files in os.walk(path+dir): # traverse each folder print path+dir+'' for file in files: images.append(Image.open(path+dir+'/'+file)) pinjie(images,num) num +=1 images = []
本文已被收录到专题《python图片处理操作》 ,欢迎大家点击学习更多精彩内容。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
python,拼接图片
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“python实现拼接图片”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年12月28日
2024年12月28日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]