1.1、切割(9*16)
# 参考网址:https://blog.csdn.net/weixin_42182534/article/details/125773141?ops_request_misc=&request_id=&biz_id=102&utm_term=python%E6%88%AA%E5%8F%96%E5%9B%BE%E7%89%87%E7%9A%84%E4%B8%80%E9%83%A8%E5%88%86&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-1-125773141.nonecase&spm=1018.2226.3001.4187'''功能:商用图片切割2048*2048,2*2
作者:阿夏
时间:2023年7月27日 19:51
'''import os
import os.pathfrom PIL import Imagelong=1632
wide=2912small_long=2
small_wide=2
# 目前图片都是2*2,3*3排列# 1:1图比例是2048
# 16:9图片比例 2912:1632
# 3:4图片比例 1856:2464
wj=int(input('文件夹名称(1人物,2卡通,3宠物,4动漫,5风景,6其他)\n'))lb=['人物','卡通','宠物','动漫','风景','其他']print(lb[wj-1])
a=(lb[wj-1])z=0
longall=[]
longall.append(z)
for l in range(1,small_long+1):ll=float(long/small_long*l)longall.append(ll)
print(longall)
# 右侧边的所有参数 长/X
# [0, 512, 1024, 1536, 2048]wideall=[]
wideall.append(z)
for w in range(1,small_wide+1):ww=float(wide/small_wide*w) wideall.append(ww)
print(wideall)
# 下边的所有参数 宽/X
# [0, 682.6666666666666, 1365.3333333333333, 2048.0]pic=[]
for x in range(0,small_wide):for y in range(0,small_long):z1=longall[y]z2=wideall[x]z3=longall[y+1]z4=wideall[x+1]pic.append(z1)pic.append(z2)pic.append(z3)pic.append(z4)
print(len(pic))# 定义文件所在文件夹
image_dir = r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}原图'.format(lb[wj-1])
for parent, dir_name, file_names in os.walk(image_dir): # 遍历每一张图片for filename in file_names:print(filename)pic_name = os.path.join(parent, filename)image = Image.open(pic_name)_width, _height = image.sizeprint(_width, _height)qfall=4# 每张图有4个坐标n=0 for p in range(int(len(pic)/4)):pp=pic[p*4:p*4+4]print(pp)# 定义裁剪范围(left, upper, right, lower)1024# # box = image.crop((0,0,123,123))box = image.crop((pp[0],pp[1],pp[2],pp[3]))name = filename[:-4]+'_'+str(n) +'.png'print(name)# # # ,pp[3],pp[4],pp[5],pp[6],pp[7],pp[8],pp[9]))# # name = filename[:-4]+'_'+str(p) +'.png'2048box.save(r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}六图\{}'.format((lb[wj-1]),name))n+=1# print('Done!') # 新建几个文件夹import os
# type=int(input('输入名字.0人物 1卡通 2宠物 3动漫 4风景 5其他\n'))# 建立文件夹
l=['01多余','02检查完成','03过度修改','04待定','05占位','06占位','07占位','08占位',]for t in l:# 新建所有空白的文件夹dir =r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}六图\{}'.format(lb[wj-1],t)if not os.path.exists(dir):os.makedirs(dir)
1.2、切割(16*9)
# 参考网址:https://blog.csdn.net/weixin_42182534/article/details/125773141?ops_request_misc=&request_id=&biz_id=102&utm_term=python%E6%88%AA%E5%8F%96%E5%9B%BE%E7%89%87%E7%9A%84%E4%B8%80%E9%83%A8%E5%88%86&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-1-125773141.nonecase&spm=1018.2226.3001.4187'''功能:商用图片切割2048*2048,2*2
作者:阿夏
时间:2023年7月27日 19:51
'''import os
import os.pathfrom PIL import Imagelong=2912
wide=1632small_long=2
small_wide=2
# 目前图片都是2*2,3*3排列# 1:1图比例是2048
# 16:9图片比例 2912:1632
# 3:4图片比例 1856:2464
wj=int(input('文件夹名称(1人物,2卡通,3宠物,4动漫,5风景,6其他)\n'))lb=['人物','卡通','宠物','动漫','风景','其他']print(lb[wj-1])
a=(lb[wj-1])z=0
longall=[]
longall.append(z)
for l in range(1,small_long+1):ll=float(long/small_long*l)longall.append(ll)
print(longall)
# 右侧边的所有参数 长/X
# [0, 512, 1024, 1536, 2048]wideall=[]
wideall.append(z)
for w in range(1,small_wide+1):ww=float(wide/small_wide*w) wideall.append(ww)
print(wideall)
# 下边的所有参数 宽/X
# [0, 682.6666666666666, 1365.3333333333333, 2048.0]pic=[]
for x in range(0,small_wide):for y in range(0,small_long):z1=longall[y]z2=wideall[x]z3=longall[y+1]z4=wideall[x+1]pic.append(z1)pic.append(z2)pic.append(z3)pic.append(z4)
print(len(pic))# 定义文件所在文件夹
image_dir = r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}原图'.format(lb[wj-1])
for parent, dir_name, file_names in os.walk(image_dir): # 遍历每一张图片for filename in file_names:print(filename)pic_name = os.path.join(parent, filename)image = Image.open(pic_name)_width, _height = image.sizeprint(_width, _height)qfall=4# 每张图有4个坐标n=0 for p in range(int(len(pic)/4)):pp=pic[p*4:p*4+4]print(pp)# 定义裁剪范围(left, upper, right, lower)1024# # box = image.crop((0,0,123,123))box = image.crop((pp[0],pp[1],pp[2],pp[3]))name = filename[:-4]+'_'+str(n) +'.png'print(name)# # # ,pp[3],pp[4],pp[5],pp[6],pp[7],pp[8],pp[9]))# # name = filename[:-4]+'_'+str(p) +'.png'2048box.save(r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}六图\{}'.format((lb[wj-1]),name))n+=1# print('Done!') # 新建几个文件夹import os
# type=int(input('输入名字.0人物 1卡通 2宠物 3动漫 4风景 5其他\n'))# 建立文件夹
l=['01多余','02检查完成','03过度修改','04待定','05占位','06占位','07占位','08占位',]for t in l:# 新建所有空白的文件夹dir =r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}六图\{}'.format(lb[wj-1],t)if not os.path.exists(dir):os.makedirs(dir)
1.3切割(1*1)
# 参考网址:https://blog.csdn.net/weixin_42182534/article/details/125773141?ops_request_misc=&request_id=&biz_id=102&utm_term=python%E6%88%AA%E5%8F%96%E5%9B%BE%E7%89%87%E7%9A%84%E4%B8%80%E9%83%A8%E5%88%86&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-1-125773141.nonecase&spm=1018.2226.3001.4187'''功能:商用图片切割2048*2048,2*2
作者:阿夏
时间:2023年7月27日 19:51
'''import os
import os.pathfrom PIL import Imagelong=2048
wide=2048small_long=2
small_wide=2
# 目前图片都是2*2,3*3排列# 1:1图比例是2048
# 16:9图片比例 2912:1632
# 3:4图片比例 1856:2464
wj=int(input('文件夹名称(1人物,2卡通,3宠物,4动漫,5风景,6其他)\n'))lb=['人物','卡通','宠物','动漫','风景','其他']print(lb[wj-1])
a=(lb[wj-1])z=0
longall=[]
longall.append(z)
for l in range(1,small_long+1):ll=float(long/small_long*l)longall.append(ll)
print(longall)
# 右侧边的所有参数 长/X
# [0, 512, 1024, 1536, 2048]wideall=[]
wideall.append(z)
for w in range(1,small_wide+1):ww=float(wide/small_wide*w) wideall.append(ww)
print(wideall)
# 下边的所有参数 宽/X
# [0, 682.6666666666666, 1365.3333333333333, 2048.0]pic=[]
for x in range(0,small_wide):for y in range(0,small_long):z1=longall[y]z2=wideall[x]z3=longall[y+1]z4=wideall[x+1]pic.append(z1)pic.append(z2)pic.append(z3)pic.append(z4)
print(len(pic))# 定义文件所在文件夹
image_dir = r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}原图'.format(lb[wj-1])
for parent, dir_name, file_names in os.walk(image_dir): # 遍历每一张图片for filename in file_names:print(filename)pic_name = os.path.join(parent, filename)image = Image.open(pic_name)_width, _height = image.sizeprint(_width, _height)qfall=4# 每张图有4个坐标n=0 for p in range(int(len(pic)/4)):pp=pic[p*4:p*4+4]print(pp)# 定义裁剪范围(left, upper, right, lower)1024# # box = image.crop((0,0,123,123))box = image.crop((pp[0],pp[1],pp[2],pp[3]))name = filename[:-4]+'_'+str(n) +'.png'print(name)# # # ,pp[3],pp[4],pp[5],pp[6],pp[7],pp[8],pp[9]))# # name = filename[:-4]+'_'+str(p) +'.png'2048box.save(r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}六图\{}'.format((lb[wj-1]),name))n+=1# print('Done!') # 新建几个文件夹import os
# type=int(input('输入名字.0人物 1卡通 2宠物 3动漫 4风景 5其他\n'))# 建立文件夹
l=['01多余','02检查完成','03过度修改','04待定','05占位','06占位','07占位','08占位',]for t in l:# 新建所有空白的文件夹dir =r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}六图\{}'.format(lb[wj-1],t)if not os.path.exists(dir):os.makedirs(dir)
-----------------------------------------------------------------------------------------
2.1 四图转成 800_800KB测试最大自动筛选
# 参考网址:https://blog.csdn.net/weixin_42182534/article/details/125773141?ops_request_misc=&request_id=&biz_id=102&utm_term=python%E6%88%AA%E5%8F%96%E5%9B%BE%E7%89%87%E7%9A%84%E4%B8%80%E9%83%A8%E5%88%86&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-1-125773141.nonecase&spm=1018.2226.3001.4187wj=int(input('文件夹名称(1人物,2卡通,3宠物,4动漫,5风景,6其他)\n'))lb=['人物','卡通','宠物','动漫','风景','其他']import os
from PIL import Image
from PIL import ImageFile
import shutilprint('----第1步:新建临时文件夹,把png替换成jpg,做出十套图片-----')
z1=[]
for zz in range(10,101):z1.append(zz)dirname_read= r'C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/{}六图/'.format(lb[wj-1]) # 注意后面的斜杠dirname_write=r'C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/{}八百/'.format(lb[wj-1])names=os.listdir(dirname_read)count=0for name in names:img=Image.open(dirname_read+name)img.thumbnail((800, 800),Image.ANTIALIAS) # 调整图片的尺寸长宽 高质量# img.resize((800, 800),Image.ANTIALIAS) # 调整图片的尺寸长宽 高质量 name=name.split(".")if name[-1] == "png":name[-1] = "jpg"name = str.join(".", name)to_save_path = dirname_write + nameimg = img.convert('RGB')#RGBA意思是红色,绿色,蓝色,Alpha的色彩空间,Alpha指透明度。而JPG不支持透明度,所以要么丢弃Alpha,要么保存为.png文件img.save(to_save_path,"JPEG",quality=zz, optimize=True, progressive=True)# 96 31.6# 没有33.1count+=1print(name)else:continue pathone=[]pr=r"C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百".format(lb[wj-1])# 风景变小:160张放在一起、# 风景八百:拆成6张放在一起# print(pr)# 过滤:只保留jpg结尾的图片imgs=os.listdir(pr)for img in imgs:if img.endswith(".jpg"):pathone.append(pr+'\\'+img)print(pathone)c=int(len(pathone))print(c)# # # 创建多少个文件夹# # # 文件名称001 002 两次都仙剑了5个文件夹# # # list1=[] for t in range(1,int(len(pathone)/6)+1):# 第一次从1开始,name='{}_{}_{}'.format(format(lb[wj-1]),'%03d'%t,str(zz))# 风景_001print(name)# 文件序号确定 u='{}{}素材'.format('%02d'%wj,format(lb[wj-1]))c='临时文件夹'dir =pathone[t-1][0:35] +'\\'+c+'\\'+name+'\\'print(dir) # 新建拼合文件夹if not os.path.exists(dir):os.makedirs(dir)tt=pathone[(t-1)*6:(t-1)*6+6]# 0-5 5-10print(tt)for ttt in tt:print(ttt)list_old=ttt# # print(list_old)list_new=dir# # # 复制文件(先不要删除)shutil.copy(list_old,list_new)# test_masked=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\卡通八百'
print('----第2步:清空人物/卡通八百里面的数据并新建八百-----')
# 清空并新建八百dirdir =r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百'.format(lb[wj-1])
# # 删除所有有图片或没有图片的文件夹
if os.path.exists(dirdir):shutil.rmtree(dirdir)# shutil.remove(dir)# shutil.removedirs(dir)
else:pass
# # 新建人物八百的文件夹
if not os.path.exists(dirdir):os.makedirs(dirdir)print('----第3步:读取文件夹大小,确定范围,并筛选最大文件夹的6张图片的路径,复制到人物/卡通八百-----')# # # 挑选最大KB的图片,并复制到八百里,删除临时文件夹test_old=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\临时文件夹'
test_new=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百'.format(lb[wj-1]) x=len(z1)
# print(x)lj=[]
ims=os.listdir(test_old)
for im in ims:lj.append(test_old+'\\'+im)
# print(lj)
# # 只要文件夹
# print(len(lj))
# 文件夹数量95个# # 十个数字内部进行比较
z2=[]
for a2 in range(int(len(lj)/x)):c=lj[a2*x:a2*x+x]z2.append(c)
# print(z2)
#
# l_idx=[]
l_num=[]
l_path=[]
l_end=[]for f in z2:l_num.clear() l_path.clear() for retall in f: # print(retall) # 路径+图片名称 name = os.path.basename(retall)sum = 0def func(dirpath):lst = os.listdir(dirpath) # 大文件夹下文件列表,包括文件夹for el in lst:new_dir = dirpath+'\\'+elif os.path.isfile(new_dir):getsize = os.path.getsize(new_dir)global sumsum += getsizeelse:func(new_dir)return sumnum = func(retall)KB=int(num/1024)print(KB)if 300<=KB<400:# 删选出300-400KB的图片,添加到列表l_num.append(KB)l_path.append(retall)print(l_num)print(l_path) # KB列表里面的最大值# 注意:如果质量70-100生成的KB不在300-400之间,会出现空值,程序中断,所以最好把1-100都循环一次,但是这样时间很长,36份6张 做10-90 91套需要生成3276个文件夹。大约1个小时,1.65GBvalue=max(l_num) # KB列表里面的最大值idx=l_num.index(value) # 最大数字虽在的索引数字# print(value,idx)# 最大KB图片的路径 l_end.append(l_path[idx])# # # 复制到新路径
tp=[]
for p4 in range(len(l_end)): o=str(l_end[p4])# print(o)ims4=os.listdir(o)# print(ims4)for im4 in ims4:tp.append(o+'\\'+im4)
# print(tp)
# # 单张图片的路径
# print(len(tp))
# 12张
#
for x in range(len(tp)): list_old=tp[x] # 临时文件夹里的路径和图片名称print(list_old)# C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\人物八百list_new=test_new+'\\'+list_old[52:0]print(list_new)# # # # 复制文件(先不要删除)shutil.copy(list_old,list_new)print('----第4步:删除临时文件夹-----')# #
# 删除临时文件夹
if os.path.exists(test_old):shutil.rmtree(test_old)# shutil.remove(dir)# # shutil.removedirs(dir)
2.2 四图转成 800_800KB测试最大自动筛选
# 参考网址:https://blog.csdn.net/weixin_42182534/article/details/125773141?ops_request_misc=&request_id=&biz_id=102&utm_term=python%E6%88%AA%E5%8F%96%E5%9B%BE%E7%89%87%E7%9A%84%E4%B8%80%E9%83%A8%E5%88%86&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-1-125773141.nonecase&spm=1018.2226.3001.4187'''
图片6张都整理好以后把风景六图改成风景八百
'''
wj=int(input('文件夹名称(1人物,2卡通,3宠物,4动漫,5风景,6其他)\n'))
# zz=int(input('800压缩质量83(最后检查一下是否最大,可以多做几份,把最大的那几分拿出来)\n'))date=input('请输入日期"0708"\n')bh=int(input('分组文件夹的数字,,1(卡通001套)\n'))lb=['人物','卡通','宠物','动漫','风景','其他']print('----第1步:新建临时文件夹,把png替换成jpg,做出十套图片-----')
import os
from PIL import Image
from PIL import ImageFile
import shutilz1=[]
for zz in range(90,105):z1.append(zz) # 确定组数,5个5个做对比# print(z1)dirname_read= r'C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/{}六图/'.format(lb[wj-1]) # 注意后面的斜杠dirname_write=r'C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/{}八百/'.format(lb[wj-1])names=os.listdir(dirname_read)count=0for name in names:img=Image.open(dirname_read+name)img.thumbnail((1280, 720),Image.ANTIALIAS) # 调整图片的尺寸长宽 高质量# img.resize((800, 800),Image.ANTIALIAS) # 调整图片的尺寸长宽 高质量 name=name.split(".")if name[-1] == "png":name[-1] = "jpg"name = str.join(".", name)to_save_path = dirname_write + nameimg = img.convert('RGB')#RGBA意思是红色,绿色,蓝色,Alpha的色彩空间,Alpha指透明度。而JPG不支持透明度,所以要么丢弃Alpha,要么保存为.png文件img.save(to_save_path,"JPEG",quality=zz, optimize=True, progressive=True)# 96 31.6# 没有33.1count+=1# print(name)else:continuell=['变小','八百']import shutilpathone=[]pr=r"C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百".format(lb[wj-1])# 风景变小:160张放在一起、# 风景八百:拆成6张放在一起# print(pr)# 过滤:只保留jpg结尾的图片imgs=os.listdir(pr)for img in imgs:if img.endswith(".jpg"):pathone.append(pr+'\\'+img)# print(pathone)c=int(len(pathone))# print(c)for t in range(1,int(len(pathone)/1)+1):c='临时文件夹'dir =pathone[t-1][0:35] +'\\'+c+ '\\'# 新建拼合文件夹if not os.path.exists(dir):os.makedirs(dir)# 只传1张图片,没有文件夹tt=pathone[t-1]# 0-5 5-10list_old=tt# list_new=dir+pathone[t-1][41:-4]+'_{}'.format(str(zz))+'.jpg'print(list_new)# # # 复制文件(先不要删除)shutil.copy(list_old,list_new)# test_masked=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\卡通八百'
print('----第2步:清空八百里面的数据并新建八百-----')
# 清空并新建八百dirdir =r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百'.format(lb[wj-1])
# # 删除所有有图片或没有图片的文件夹
if os.path.exists(dirdir):shutil.rmtree(dirdir)# shutil.remove(dir)# shutil.removedirs(dir)
else:pass
# # 新建所有空白的文件夹
if not os.path.exists(dirdir):os.makedirs(dirdir)print('----第3步:读取图片大小,确定范围,并筛选最大的的图片的路径,复制到卡通八百-----')# # # 挑选最大KB的图片,并复制到八百里,删除临时文件夹test_new=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百'.format(lb[wj-1])
test_old=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\临时文件夹'lj=[]
ims=os.listdir(test_old)
for im in ims:if im.endswith(".jpg"):lj.append(test_old+'\\'+im)
# print(lj)
# print(len(lj))
# 十个数字内部进行比较x=len(z1)
z2=[]
for a2 in range(int(len(lj)/x)):c=lj[a2*x:a2*x+x]z2.append(c)
# print(z2)
#
# l_idx=[]
l_num=[]
l_path=[]
l_end=[]for f in z2:l_num.clear() l_path.clear() for d in f: # print(d) # 路径+图片名称 imageSize = os.path.getsize(d)imageSize /= 1024 # 除以1024是代表Kbe=int(round(imageSize))# print(e)if 300<=e<400:# 删选出300-400KB的图片,添加到列表l_num.append(e)l_path.append(d)print(l_num)print(l_path) # KB列表里面的最大值value=max(l_num) # KB列表里面的最大值idx=l_num.index(value) # 最大数字虽在的索引数字# print(value,idx)# 最大KB图片的路径 l_end.append(l_path[idx])# print(l_num)
# print(l_path)# 最大两张图片的路径
print(l_end)
print(len(l_end))
for a in l_end:print(a)
# ['C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\AI商业接单\\临时文件夹\\001_1_97.jpg', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\AI商业接单\\临时文件夹\\001_2_96.jpg']# 复制到新路径for p in range(len(l_end)):list_old=l_end[p] # 临时文件夹里的路径和图片名称print(list_old)list_new=test_new+'\\'+list_old[42:-7]+'.jpg'print(list_new)# # # 复制文件(先不要删除)shutil.copy(list_old,list_new)print('----第4步:删除临时文件夹-----')# #
# 删除临时文件夹
if os.path.exists(test_old):shutil.rmtree(test_old)# shutil.remove(dir)# # shutil.removedirs(dir)print('----第5步:把卡通八百内容复制到指定的卡通里面的001里面-----')# # pathtwo=[]
pr2=r"C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百".format(lb[wj-1]) # 过滤:只保留jpg结尾的图片
imgs2=os.listdir(pr2)
for img2 in imgs2:if img2.endswith(".jpg"):pathtwo.append(pr2+'\\'+img2)
# print(pathtwo)
c2=int(len(pathtwo))
print(c2)# 新建文件夹
bigname='2023{}_{}素材{}号({}份)'.format(date,lb[wj-1],'%03d'%bh,int(c2))# 新建一个黄色文件夹
dir3 =r"C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}{}素材\{}".format('%02d'%wj,lb[wj-1],bigname)
if not os.path.exists(dir3):os.makedirs(dir3)# 图片从旧路径替换到新路径
for t2 in range(len(pathtwo)):list_old2 =pathtwo[t2]print(list_old2)list_new2=dir3+"\\"+pathtwo[t2][41:]print(list_new2)# # # 复制文件(先不要删除)shutil.copy(list_old2,list_new2)
2.301-00-03 四图转成 720_1280KB 测试最大合并汇总
# 参考网址:https://blog.csdn.net/weixin_42182534/article/details/125773141?ops_request_misc=&request_id=&biz_id=102&utm_term=python%E6%88%AA%E5%8F%96%E5%9B%BE%E7%89%87%E7%9A%84%E4%B8%80%E9%83%A8%E5%88%86&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-1-125773141.nonecase&spm=1018.2226.3001.4187'''
图片6张都整理好以后把风景六图改成风景八百
'''
wj=int(input('文件夹名称(1人物,2卡通,3宠物,4动漫,5风景,6其他)\n'))
# zz=int(input('800压缩质量83(最后检查一下是否最大,可以多做几份,把最大的那几分拿出来)\n'))date=input('请输入日期"0708"\n')bh=int(input('分组文件夹的数字,,1(卡通001套)\n'))lb=['人物','卡通','宠物','动漫','风景','其他']print('----第1步:新建临时文件夹,把png替换成jpg,做出十套图片-----')
import os
from PIL import Image
from PIL import ImageFile
import shutilz1=[]
for zz in range(90,105):z1.append(zz) # 确定组数,5个5个做对比# print(z1)dirname_read= r'C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/{}六图/'.format(lb[wj-1]) # 注意后面的斜杠dirname_write=r'C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/{}八百/'.format(lb[wj-1])names=os.listdir(dirname_read)count=0for name in names:img=Image.open(dirname_read+name)img.thumbnail((720, 1280),Image.ANTIALIAS) # 调整图片的尺寸长宽 高质量# img.resize((800, 800),Image.ANTIALIAS) # 调整图片的尺寸长宽 高质量 name=name.split(".")if name[-1] == "png":name[-1] = "jpg"name = str.join(".", name)to_save_path = dirname_write + nameimg = img.convert('RGB')#RGBA意思是红色,绿色,蓝色,Alpha的色彩空间,Alpha指透明度。而JPG不支持透明度,所以要么丢弃Alpha,要么保存为.png文件img.save(to_save_path,"JPEG",quality=zz, optimize=True, progressive=True)# 96 31.6# 没有33.1count+=1# print(name)else:continuell=['变小','八百']import shutilpathone=[]pr=r"C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百".format(lb[wj-1])# 风景变小:160张放在一起、# 风景八百:拆成6张放在一起# print(pr)# 过滤:只保留jpg结尾的图片imgs=os.listdir(pr)for img in imgs:if img.endswith(".jpg"):pathone.append(pr+'\\'+img)# print(pathone)c=int(len(pathone))# print(c)for t in range(1,int(len(pathone)/1)+1):c='临时文件夹'dir =pathone[t-1][0:35] +'\\'+c+ '\\'# 新建拼合文件夹if not os.path.exists(dir):os.makedirs(dir)# 只传1张图片,没有文件夹tt=pathone[t-1]# 0-5 5-10list_old=tt# list_new=dir+pathone[t-1][41:-4]+'_{}'.format(str(zz))+'.jpg'print(list_new)# # # 复制文件(先不要删除)shutil.copy(list_old,list_new)# test_masked=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\卡通八百'
print('----第2步:清空八百里面的数据并新建八百-----')
# 清空并新建八百dirdir =r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百'.format(lb[wj-1])
# # 删除所有有图片或没有图片的文件夹
if os.path.exists(dirdir):shutil.rmtree(dirdir)# shutil.remove(dir)# shutil.removedirs(dir)
else:pass
# # 新建所有空白的文件夹
if not os.path.exists(dirdir):os.makedirs(dirdir)print('----第3步:读取图片大小,确定范围,并筛选最大的的图片的路径,复制到卡通八百-----')# # # 挑选最大KB的图片,并复制到八百里,删除临时文件夹test_new=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百'.format(lb[wj-1])
test_old=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\临时文件夹'lj=[]
ims=os.listdir(test_old)
for im in ims:if im.endswith(".jpg"):lj.append(test_old+'\\'+im)
# print(lj)
# print(len(lj))
# 十个数字内部进行比较x=len(z1)
z2=[]
for a2 in range(int(len(lj)/x)):c=lj[a2*x:a2*x+x]z2.append(c)
# print(z2)
#
# l_idx=[]
l_num=[]
l_path=[]
l_end=[]for f in z2:l_num.clear() l_path.clear() for d in f: # print(d) # 路径+图片名称 imageSize = os.path.getsize(d)imageSize /= 1024 # 除以1024是代表Kbe=int(round(imageSize))# print(e)if 300<=e<400:# 删选出300-400KB的图片,添加到列表l_num.append(e)l_path.append(d)print(l_num)print(l_path) # KB列表里面的最大值value=max(l_num) # KB列表里面的最大值idx=l_num.index(value) # 最大数字虽在的索引数字# print(value,idx)# 最大KB图片的路径 l_end.append(l_path[idx])# print(l_num)
# print(l_path)# 最大两张图片的路径
print(l_end)
print(len(l_end))
for a in l_end:print(a)
# ['C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\AI商业接单\\临时文件夹\\001_1_97.jpg', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\AI商业接单\\临时文件夹\\001_2_96.jpg']# 复制到新路径for p in range(len(l_end)):list_old=l_end[p] # 临时文件夹里的路径和图片名称print(list_old)list_new=test_new+'\\'+list_old[42:-7]+'.jpg'print(list_new)# # # 复制文件(先不要删除)shutil.copy(list_old,list_new)print('----第4步:删除临时文件夹-----')# #
# 删除临时文件夹
if os.path.exists(test_old):shutil.rmtree(test_old)# shutil.remove(dir)# # shutil.removedirs(dir)# print('----第5步:把卡通八百内容复制到指定的卡通里面的001里面-----')# # # pathtwo=[]
# pr2=r"C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百".format(lb[wj-1]) # # 过滤:只保留jpg结尾的图片
# imgs2=os.listdir(pr2)
# for img2 in imgs2:
# if img2.endswith(".jpg"):
# pathtwo.append(pr2+'\\'+img2)
# # print(pathtwo)
# c2=int(len(pathtwo))
# print(c2)# # 新建文件夹
# bigname='2023{}_{}素材{}号({}份)'.format(date,lb[wj-1],'%03d'%bh,int(c2))# # 新建一个黄色文件夹
# dir3 =r"C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}{}素材\{}".format('%02d'%wj,lb[wj-1],bigname)
# if not os.path.exists(dir3):
# os.makedirs(dir3)# # 图片从旧路径替换到新路径
# for t2 in range(len(pathtwo)):# list_old2 =pathtwo[t2]
# print(list_old2)# list_new2=dir3+"\\"+pathtwo[t2][41:]
# print(list_new2)
# # # # 复制文件(先不要删除)
# shutil.copy(list_old2,list_new2)
3.1 3乘2图变小图片最大化
# # -*- coding: utf-8 -*-
# import fitz'''
AI商业接单2.0(一页2份 动物朝向有的左侧、有的右侧)
目的:
1、AI商业接单涂色
2、AI商业接单排序
3、AI商业接单分类(向左向右)
作者:阿夏
时间:2023年4月15日)'''# 参考网址:https://blog.csdn.net/weixin_42182534/article/details/125773141?ops_request_misc=&request_id=&biz_id=102&utm_term=python%E6%88%AA%E5%8F%96%E5%9B%BE%E7%89%87%E7%9A%84%E4%B8%80%E9%83%A8%E5%88%86&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-1-125773141.nonecase&spm=1018.2226.3001.4187'''
图片6张都整理好以后把风景六图改成风景八百,用来最后转移到6图文件夹
'''print('----0,输入参数- ---')wj=int(input('文件夹名称(1人物,2卡通,3宠物,4动漫,5风景,6其他)\n'))lb=['人物','卡通','宠物','动漫','风景','其他']print('----------第2步:提取六张图片的路径------------')import os
from PIL import Imagelb=['人物','卡通','宠物','动漫','风景','其他']
print(lb[wj-1])
a=(lb[wj-1])z1=[]
for zz in range(90,102):z1.append(zz)path=[]pr=r"C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}六图".format(a)# 过滤:只保留png结尾的图片imgs=os.listdir(pr)for img in imgs:if img.endswith(".png"):path.append(pr+'\\'+img)figure=[]for p in range(int(len(path)/6)):pp=path[p*6:p*6+6]figure.append(pp)print(figure)print(len(figure))print('----------第3步:新建一个临时文件夹------------')# 新建一个”装N份word和PDF“的文件夹os.mkdir(r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\零时Word')print('----------第4步:写入图片 ------------')import osimport randomimport timeimport docximport pandas as pdfrom docx import Documentfrom docx2pdf import convertfrom docx.enum.text import WD_PARAGRAPH_ALIGNMENTfrom docx.oxml.ns import qnfrom docx.shared import Cm, Inches, Pt, RGBColorfrom docxtpl import DocxTemplatefor nn in range(0,int(len(path)/6)): doc = Document(r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\6格单图模板_1024_720(顶格).docx')# 6格图模板 - 副本.docx')# # figures=[]# for f in range(len(path))): # 02# 单元格位置/3*4格bg=[]for x in range(0,3,2): # 4行for y in range(1,6,2): # 3列ww='{}{}'.format(x,y)bg.append(ww)print(bg) # ['00', '02', '04', '20', '22', '24']table = doc.tables[0] # 4567(8)行for t in range(len(bg)): # 02pp=int(bg[t][0]) qq=int(bg[t][1]) # print(p) k=figure[nn][t] print(pp,qq,k)# 写入图片run=doc.tables[0].cell(pp,qq).paragraphs[0].add_run() # 在第1个表格中第2个单元格内插入国旗run.add_picture('{}'.format(k),width=Cm(13.3),height=Cm(13.3))table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER#居中 # # 写入序号和生肖名称# run=table.cell(pp,qq).paragraphs[0].add_run(k2) # 在单元格0,0(第1行第1列)输入第0个图图案# run.font.name = '黑体'#输入时默认华文彩云字体# # run.font.size = Pt(46) #输入字体大小默认30号 换行(一页一份大卡片# run.font.size = Pt(29) #输入字体大小默认30号 一行里(可以一页两份)# run.font.bold= True #是否加粗# run.font.color.rgb = RGBColor(200,200,200) #数字小,颜色深0-255# # paragraph.paragraph_format.line_spacing = Pt(180) #数字段间距# r = run._element# r.rPr.rFonts.set(qn('w:eastAsia'), '黑体')#将输入语句中的中文部分字体变为华文行楷# table.cell(pp,qq).paragraphs[0].alignment = WD_PARAGRAPH_ALIGNMENT.CENTER #居中 doc.save(r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\零时Word\{}.docx'.format('%02d'%nn)) from docx2pdf import convert# docx 文件另存为PDF文件inputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/零时Word/{}.docx".format('%02d'%nn) # 要转换的文件:已存在outputFile = r"C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/零时Word/{}.pdf".format('%02d'%nn) # 要生成的文件:不存在# 先创建 不存在的 文件f1 = open(outputFile, 'w')f1.close()# 再转换往PDF中写入内容convert(inputFile, outputFile)print('----------第5步:把都有PDF合并为一个打印用PDF------------')# 多个PDF合并(CSDN博主「红色小小螃蟹」,https://blog.csdn.net/yangcunbiao/article/details/125248205)import osfrom PyPDF2 import PdfFileMergertarget_path = 'C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/零时Word'pdf_lst = [f for f in os.listdir(target_path) if f.endswith('.pdf')]pdf_lst = [os.path.join(target_path, filename) for filename in pdf_lst]pdf_lst.sort()file_merger = PdfFileMerger()for pdf in pdf_lst:print(pdf)file_merger.append(pdf)file_merger.write("C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/{}素材PDF.pdf".format(a))file_merger.close()# doc.Close()# print('----------第5步:删除临时文件夹------------') import shutilshutil.rmtree('C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/零时Word') #递归删除文件夹,即:删除非空文件夹print('--------------6.pdf转成图片,1028*720,350-400zKB之间------------')import datetimeimport osimport fitz # fitz就是pip install PyMuPDFdef pyMuPDF_fitz(pdfPath, imagePath):startTime_pdf2img = datetime.datetime.now() # 开始时间print("imagePath=" + imagePath)pdfDoc = fitz.open(pdfPath)for pg in range(pdfDoc.pageCount):page = pdfDoc[pg]rotate = int(0)# 每个尺寸的缩放系数为1.3,这将为我们生成分辨率提高2.6的图像。# 此处若是不做设置,默认图片大小为:792X612, dpi=96# zoom_x = 1.33333333 # (1.33333333-->1056x816) (2-->1584x1224)# zoom_y = 1.33333333zoom_x = 2 # (1.33333333-->1056x816) (2-->1584x1224)zoom_y = 2 mat = fitz.Matrix(zoom_x, zoom_y).preRotate(rotate)pix = page.getPixmap(matrix=mat, alpha=False)if not os.path.exists(imagePath): # 判断存放图片的文件夹是否存在os.makedirs(imagePath) # 若图片文件夹不存在就创建pix.writePNG(imagePath + '/' + '{}{}.png'.format(a,'%03d'% (pg+1))) # 将图片写入指定的文件夹内endTime_pdf2img = datetime.datetime.now() # 结束时间print('pdf2img时间=', (endTime_pdf2img - startTime_pdf2img).seconds)if __name__ == "__main__":# 1、PDF地址pdfPath = r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}素材PDF.pdf'.format(a)# 2、需要储存图片的目录imagePath = r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}拼合'.format(a)pyMuPDF_fitz(pdfPath, imagePath)print('----7.把1028(720png替换成jpg-----')import osfrom PIL import Imagedirname_read= r'C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/{}拼合/'.format(a) # 注意后面的斜杠dirname_write=r'C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/临时文件夹/'if not os.path.exists(dirname_write):os.makedirs(dirname_write)names=os.listdir(dirname_read)count=0for name in names:img=Image.open(dirname_read+name)img=img.resize((1280, 720)) # 调整图片的尺寸可以任意调整大小,原图16:9,可能改成1:1# img.thumbnail((1280, 720)) # 调整图片的尺寸等比例缩小,原图16:9,缩放后就是16:9,不能改成1:1name=name.split(".")if name[-1] == "png":name[-1] = "jpg"name = str.join(".", name)to_save_path = dirname_write + name[:-4]+'_{}'.format(zz)+'.jpg'img = img.convert('RGB')#RGBA意思是红色,绿色,蓝色,Alpha的色彩空间,Alpha指透明度。而JPG不支持透明度,所以要么丢弃Alpha,要么保存为.png文件img.save(to_save_path,"JPEG", quality=zz, optimize=True, progressive=True)# q=100,570KB q=98 400KB q=97 352KB q=96 300-400之间 352KB q=95 280KB count+=1print(name)else:continueprint('运行完成!共转换了 %d 张图片' % (count))print('----第3步:读取文件夹大小,确定范围,并筛选最大文件夹的6张图片的路径,复制到人物/卡通八百-----')# # # 挑选最大KB的图片,并复制到八百里,删除临时文件夹test_old=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\临时文件夹'
test_new=r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}变小'.format(lb[wj-1]) x=len(z1)
# print(x)lj=[]
ims=os.listdir(test_old)
for im in ims:lj.append(test_old+'\\'+im)
print(lj)
# # 只要文件夹
print(len(lj))
# 文件夹数量95个# # 十个数字内部进行比较
z2=[]
for a2 in range(int(len(lj)/x)):c=lj[a2*x:a2*x+x]z2.append(c)
# print(z2)
#
l_idx=[]
l_num=[]
l_path=[]
l_end=[]for f in z2:l_num.clear() l_path.clear() for retall in f: print(retall) # 路径+图片名称 # # print(d) # 路径+图片名称 imageSize = os.path.getsize(retall)imageSize /= 1024 # 除以1024是代表Kbe=int(round(imageSize))# print(e)if 300<=e<400:# 删选出300-400KB的图片,添加到列表l_num.append(e)l_path.append(retall)print(l_num)print(l_path) # KB列表里面的最大值# 注意:如果质量70-100生成的KB不在300-400之间,会出现空值,程序中断,所以最好把1-100都循环一次,但是这样时间很长,36份6张 做10-90 91套需要生成3276个文件夹。大约1个小时,1.65GBvalue=max(l_num) # KB列表里面的最大值idx=l_num.index(value) # 最大数字虽在的索引数字# print(value,idx)# 最大KB图片的路径 l_end.append(l_path[idx])
print(l_end)# # # 复制到新路径# tp=[]
# for p4 in range(len(l_end)):
# o=str(l_end[p4])
# # print(o)
# ims4=os.listdir(o)
# # print(ims4)
# for im4 in ims4:
# tp.append(o+'\\'+im4)
# # print(tp)
# # # 单张图片的路径
# # print(len(tp))
# # 12张
# #
for x in range(len(l_end)): list_old=l_end[x] # 临时文件夹里的路径和图片名称print(list_old)# C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\人物八百list_new=test_new+'\\'+list_old[45:]print(list_new)# # # # # # 复制文件(先不要删除)shutil.copy(list_old,list_new)print('----第4步:删除临时文件夹-----')# #
# 删除临时文件夹
# if os.path.exists(test_old):
# shutil.rmtree(test_old)# shutil.remove(dir)# # shutil.removedirs(dir)
4.1 KB最大的单图和六图转移(这是6图和单图样式)
import os
import shutil
import globprint('----------第8步:把“风景变小”里面的图片全部转移到X、把“风景八百”里面的图片转移到6张一组------------')ll=['变小','八百']date=input('请输入日期"0708"\n')bh=int(input('分组文件夹的数字,,1(卡通001套)\n'))
wj=int(input('文件夹名称(1人物,2卡通,3宠物,4动漫,5风景,6其他)\n'))
lb=['人物','卡通','宠物','动漫','风景','其他']
print(lb[wj-1])
a=(lb[wj-1])import shutilpathone=[]
pr=r"C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}八百".format(a)# 风景变小:160张放在一起、
# 风景八百:拆成6张放在一起
# print(pr)# 过滤:只保留jpg结尾的图片
imgs=os.listdir(pr)
for img in imgs:if img.endswith(".jpg"):pathone.append(pr+'\\'+img)
# print(pathone)
c=int(len(pathone))
print(c)# 新建文件夹
bigname='2023{}_{}素材{}号({}份)'.format(date,a,'%03d'%bh,int(c/6))# 创建多少个文件夹
# 文件名称001 002 两次都仙剑了5个文件夹
# list1=[]
for t in range(1,int(len(pathone)/6)+1):# 第一次从1开始,name='{}_{}_{}'.format(date,a,'%03d'%t)# 风景_001print(name)# 文件序号确定 u='{}{}素材'.format('%02d'%wj,a)dir =pathone[t-1][0:35] +'\\'+u+'\\'+bigname+'\\'+'{}_六图({}文件夹)'.format(str(date),str(int(c/6)))+'\\'+name+'\\'# print(dir) # C:\Users\jg2yXRZ\OneDrive\桌面\实验\风景_001\变小# C:\Users\jg2yXRZ\OneDrive\桌面\实验\风景_001\# 新建拼合文件夹if not os.path.exists(dir):os.makedirs(dir)tt=pathone[(t-1)*6:(t-1)*6+6]# 0-5 5-10print(tt)for ttt in tt:print(ttt)list_old=ttt# # print(list_old)list_new=dir# # # 复制文件(先不要删除)shutil.copy(list_old,list_new)# 6图合并的单图,内容复制到03风景素材里面的单图
list_old="C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/{}变小".format(a)
print(list_old)
# # print(list_old)
list_new="C:/Users/jg2yXRZ/OneDrive/桌面/AI商业接单/{}{}素材/{}/{}_单图({}张样图)".format('%02d'%wj,lb[wj-1],bigname,date,int(c/6))
print(list_new)# # 复制文件(先不要删除)
shutil.copytree(list_old,list_new)
5.1清空文件夹
import shutil
import os# 新建文件夹list=['人物','卡通','宠物','动漫','风景','其他']
fl=['拼合','六图','原图','变小','八百']
q=int(input('1删除,2新建,3删除并新建 \n'))lb=[]
for l in range(len(list)):# print(l)for f in range(len(fl)):# print(f)zh='{}{}'.format(list[l],fl[f])lb.append(zh)
print(lb)if q ==1:for m in range(len(lb)) :dir =r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}'.format(lb[m]) # # 删除所有有图片或没有图片的文件夹if os.path.exists(dir):shutil.rmtree(dir)# shutil.remove(dir)# shutil.removedirs(dir)else:pass if q ==2:for m in range(len(lb)) :dir =r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}'.format(lb[m]) # # 新建所有空白的文件夹if not os.path.exists(dir):os.makedirs(dir)if q ==3:for m in range(len(lb)) :dir =r'C:\Users\jg2yXRZ\OneDrive\桌面\AI商业接单\{}'.format(lb[m]) # # 删除所有有图片或没有图片的文件夹if os.path.exists(dir):shutil.rmtree(dir)# shutil.remove(dir)# shutil.removedirs(dir)else:pass# # 新建所有空白的文件夹if not os.path.exists(dir):os.makedirs(dir)