背景需求:
今天学了“微信表情”的表情图上传流程,发现其中有多种尺寸参数,必须完全符合尺寸、格式,才能上传。




以上有PNG、GIF的不同,有50*50,120*120,240*240,750*400四款差异,手动修改太费时了
最终结果:各类图片的大小参数
| 序号 | 图片类型 | 尺寸 | 大小 | 图片格式: |
| 1 | 详情页/海报图 | 750×400px | ≤500px | JPEG/PNG |
| 2 | 主图(16个、24个) | 240×240px | ≤500px | GIF |
| 3 | 缩略图(16个、24个) | 120×120px | ≤200px | PNG |
| 4 | 表情单品 | 240×240px | ≤200px | PNG |
| 5 | 引导图 | 750×560px | ≤100px | PNG |
| 6 | 感谢图 | 750×750px | ≤200px | PNG |
| 7 | 聊天页图标 | 50×50px | ≤100px | PNG |
| 8 | 表情包封面图 | 240×240px | ≤500px | PNG |
| 9 | 艺术家头像 | 640×640px | ≤500px | JPEG/PNG |
| 10 | 艺术家主页横幅尺寸: | 750×400px | ≤80px | JPEG/PNG |
我想用Python一次性制作出所有尺寸参数图。便于上传

制作过程:
1、先用MJ获得头像

2、用代码切割图片3*3,
3、把小图放到PPT里添加文字

4、另存为图片,放到D盘下(路径是英文的)


图片名称为01 02 03.png(微信表情默认上传数字,汉字不行)

5、大部分图片都是正方形尺寸,只有一个详情页是长方形
1、先把正方形图片做成400*400,
2、然后新建一个400*350的白色图片
3、把两个图片水平拼在一起
4、为了拼图成功,必须要求路径中全部是数字英文,不能有汉字。所以这次的文件放到D盘了

代码展示:
#导入Image库 from PIL import Image import numpy as np import matplotlib.pyplot as plt import skimage.io as io import numpy as np import cv2 import os import shutil cs=input('D盘的文件名emoij\n') print('----------第1步:提取所有的幼儿照片的路径------------') import os path=[] p=r"D:\\{}\01原图PNG".format(cs) # 过滤:只保留png结尾的图片 31张(多几张备用) imgs=os.listdir(p) for img in imgs: if img.endswith(".png"): path.append(p+'\\'+img) # 所有图片的路径 print(path) print(imgs) # # 都是01,02 03。png print('----------第2步:新建02-08文件夹------------') # 新建一个”装N份word和PDF“的文件夹 l=['02','03动态静态大图gif240','04动态静态小图png120','05主图1张png240','06聊天页面小图png50','02详情页PNG750乘400'] for ll in l: os.mkdir(r"D:\{}\{}".format(cs,ll)) # time.sleep(3) for n in range(len(path)): #打开当前目录下 !.png 图片文件对象 old_pic = Image.open('{}'.format(path[n])) # 图片拼接 '02详情页PNG750乘400' # 1,先把正方形表情包压缩到400*400 new_pic400 = old_pic.resize((400, 400), Image.ANTIALIAS) new_pic400.save(r"D:\{}\{}\{}".format(cs,l[0],imgs[n])) # 2。新建350*400的白色图片 img=Image.new("RGB",(350,400),(255,255,255)) # 保存图片 img.save(r"D:\{}\color.png".format(cs)) # 3、拼接图片 # 读入两张图片 img1 = cv2.imread(r"D:\{}\{}\{}".format(cs,l[0],imgs[n])) img2 = cv2.imread(r"D:\{}\color.png".format(cs)) # 获取图片的宽度和高度 width, height = img1.shape[:2] # 将两张图片水平拼接 result = np.hstack((img1, img2)) # 保存拼接后的图片 cv2.imwrite(r"D:\{}\{}\{}".format(cs,l[0],imgs[n]), result) # 把02的文件转移到02详情页 src=r"D:\{}\{}".format(cs,l[0])#原文件夹路径 des=r"D:\{}\{}".format(cs,l[5])#新文件夹路径 for file in os.listdir(src): #遍历原文件夹中的文件 full_file_name = os.path.join(src, file)#把文件的完整路径得到 print("要被复制的全文件路径全名:",full_file_name) if os.path.isfile(full_file_name):#用于判断某一对象(需提供绝对路径)是否为文件 shutil.copy(full_file_name, des)#shutil.copy函数放入原文件的路径文件全名 然后放入目标文件夹 # '03动态静态大图gif240' #修改图片size为240*240,生成新图片对象 new_pic240da = old_pic.resize((240, 240), Image.ANTIALIAS) new_pic240da.save(r"D:\\{}\{}\{}.gif".format(cs,l[1],imgs[n][0:2])) '04动态静态小图png120' new_pic120 = old_pic.resize((120, 120), Image.ANTIALIAS) new_pic120.save(r"D:\\{}\{}\{}".format(cs,l[2],imgs[n])) # 05主图1张png240', new_pic240 = old_pic.resize((240, 240), Image.ANTIALIAS) new_pic240.save(r"D:\\{}\{}\{}".format(cs,l[3],imgs[n])) '06聊天页面小图png50' new_pic150 = old_pic.resize((50, 50), Image.ANTIALIAS) new_pic150.save(r"D:\\{}\{}\{}".format(cs,l[4],imgs[n])) # 删除02文件夹 shutil.rmtree('{}'.format(src)) #递归删除文件夹,即:删除非空文件夹 # shutil.rmtree(r'D:\{}\color.png'.format(cs)) #递归删除文件夹,即:删除非空文件夹 os.remove(r'D:\{}\color.png'.format(cs))
讯享网
终端运行


结果显示







3、把小图放到PPT里添加文字
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/67167.html