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)