六图备份 大容量图片

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)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/41154.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

为什么在Spring中使用@Autowired时会提示Field injection is not recommended 而@Resource不会

在使用IDEA进行开发时&#xff0c;在字段上使用Spring的依赖注入注解Autowired后会出现如下警告 Field injection is not recommended (字段注入是不被推荐的) 这个原因具体可以看看&#xff1a; 【注解使用】使用Autowired后提示&#xff1a;Field injection is not recomme…

【抖音小玩法-弹幕游戏】开发者功能测试报告提交模板

背景 字节有明确的要求&#xff0c;准入和准出更加严格&#xff0c;要求有明确的测试报告。格式如下&#xff1a; *本文参考字节wiki&#xff1a;开发者功能测试报告提交模板 网络兼容性 请确认在以下网络类型验证过插件功能 WIFI 4G 测试机型 请罗列验证过的双端机型 An…

python+django+mysql高校校园外卖点餐系统--计算机毕设项目

本文的研究目标是以高校校园外卖点餐为对象&#xff0c;使其高校校园外卖点餐为目标&#xff0c;使得高校校园外卖点餐的信息化体系发展水平提高。论文的研究内容包括对个人中心、美食分类管理、用户管理、商家管理、美食信息管理、工作人员管理、安全检查管理、系统管理、订单…

时序预测 | MATLAB实现基于GRU门控循环单元的时间序列预测-递归预测未来(多指标评价)

时序预测 | MATLAB实现基于GRU门控循环单元的时间序列预测-递归预测未来(多指标评价) 目录 时序预测 | MATLAB实现基于GRU门控循环单元的时间序列预测-递归预测未来(多指标评价)预测结果基本介绍程序设计参考资料 预测结果 基本介绍 1.Matlab实现GRU门控循环单元时间序列预测未…

复数混频器、零中频架构和高级算法开发

文章里讲解了关于射频IQ调制器、零中频架构相关的原理及技术&#xff0c;全都是干货&#xff01;其实好多同行对软件无线电的原理、IQ调制、镜像抑制都是一知半解&#xff0c;知其然不知其所以然。好好研读这篇文章&#xff0c;相信会让你有种恍然大悟的感觉。 RF工程常被视为…

Shell学习笔记之基础部分

Shell基础&#xff1a; 查看操作系统支持的shell&#xff1a; [rootrhel9 ansible]# cat /etc/shells /bin/sh /bin/bash /usr/bin/sh /usr/bin/bashShell的基本元素&#xff1a; 声明&#xff1a;声明用哪个命令解释器来解释并执行当前脚本文件中的语句&#xff0c;一般写的…

大语言模型与语义搜索;钉钉个人版启动内测,提供多项AI服务

&#x1f989; AI新闻 &#x1f680; 钉钉个人版启动内测&#xff0c;提供多项AI服务 摘要&#xff1a;钉钉个人版正式开始内测&#xff0c;面向小团队、个人用户、高校大学生等人群。该版本具有AI为核心的功能&#xff0c;包括文生文AI、文生图AI和角色化对话等。用户可通过…

【IEEE会议】第二届IEEE云计算、大数据应用与软件工程国际学术会议 (CBASE2023)

第二届IEEE云计算、大数据应用与软件工程国际学术会议 (CBASE2023&#xff09; 随着大数据时代的到来&#xff0c;对数据获取的随时性和对计算的需求也在逐渐增长。为推动大数据时代的云计算与软件工程的发展&#xff0c;促进该领域学术交流&#xff0c;在CBASE 2022成功举办的…

设计模式——经典单例

0、核心要素 // 构造、析构函数私有化&#xff08;一个进程只允许一个对象存在&#xff09; // 对象私有化、静态化&#xff08;因为接口静态函数&#xff09; // 对象调用接口静态化&#xff08;因为静态函数脱离了类对象&#xff0c;可以直接调用&#xff09; 一、懒汉 唯…

如何更好的维护自己的电脑?

我的笔记本电脑 我使用的华硕天选3是一款游戏本&#xff0c;搭载了英特尔酷睿i7-12700H处理器&#xff0c;16GB内存&#xff0c;512GB固态硬盘和NVIDIA GeForce RTX 3050显卡。屏幕尺寸为15.6英寸&#xff0c;分辨率为2560x1440。对于日常使用和工作学习娱乐都能满足要求。 日常…

基于docker搭建pytest自动化测试环境(docker+pytest+jenkins+allure)

pytest搭建自动化测试环境&#xff08;dockerpytestjenkinsallure&#xff09; 这里我以ubuntu18为例 如果有docker环境&#xff0c;可以直接拉取我打包好的镜像docker pull ziyigun/jenkins:v1.0 1 搭建Docker 1.1 安装docker # 配置docker安装环境 sudo apt-get install ap…

润和软件HopeStage操作系统正式上架阿里云、华为云、腾讯云商店

近日&#xff0c;润和软件HopeStage操作系统正式上架阿里云、华为云、腾讯云商店。 随着科技的发展&#xff0c;云服务成为现代社会信息和资讯的交换、共享、存储、检索、应用等重要方式。阿里云、华为云、腾讯云作为我国云服务市场三巨头&#xff0c;其云商店产品全面覆盖云、…

Nvidia Jetson 编解码开发(1)介绍

前言 由于项目需要,需要开发Jetson平台的硬件编解码; 优化CPU带宽,后续主要以介绍硬件编解码为主 1.Jetson各平台编解码性能说明 如下是拿了Jetson nano/tx2/Xavier等几个平台做对比; 这里说明的编解码性能主要是对硬件来说的 2. 编解码实现说明 2.1 软件编解码 优点:…

Idea中隐藏指定文件或指定类型文件

Setting ->Editor ->Code Style->File Types → Ignored Files and Folders输入要隐藏的文件名&#xff0c;支持*号通配符回车确认添加

Windows权限维持—自启动映像劫持粘滞键辅助屏保后门WinLogon

Windows权限维持—自启动&映像劫持&粘滞键&辅助屏保后门&WinLogon 1. 前置2. 自启动2.1. 路径加载2.1.1. 放置文件2.1.2. 重启主机 2.2. 服务加载2.2.1. 创建服务2.2.2. 查看服务2.2.3. 重启主机 2.3. 注册表加载2.3.1. 添加启动项2.3.2. 查看注册表2.3.3. 重启…

YOLOv5基础知识入门(7)— NMS(非极大值抑制)原理解析

前言&#xff1a;Hello大家好&#xff0c;我是小哥谈。NMS是指非极大值抑制&#xff08;non maximum suppression&#xff09;&#xff0c;它是一种常用于物体检测任务的算法。在物体检测中&#xff0c;通常会有多个预测框&#xff08;bounding box&#xff09;被提议出来&…

机器学习深度学习——transformer(机器翻译的再实现)

&#x1f468;‍&#x1f393;作者简介&#xff1a;一位即将上大四&#xff0c;正专攻机器学习的保研er &#x1f30c;上期文章&#xff1a;机器学习&&深度学习——自注意力和位置编码&#xff08;数学推导代码实现&#xff09; &#x1f4da;订阅专栏&#xff1a;机器…

【论文阅读】 Model Sparsity Can Simplify Machine Unlearning

Model Sparsity Can Simplify Machine Unlearning 背景主要内容Contribution Ⅰ&#xff1a;对Machine Unlearning的一个全面的理解Contribution Ⅱ&#xff1a;说明model sparsity对Machine Unlearning的好处Pruning方法的选择sparse-aware的unlearning framework Experiments…

JetBrains IDE远程开发功能可供GitHub用户使用

JetBrains与GitHub去年已达成合作&#xff0c;提供GitHub Codespaces 与 JetBrains Gateway 之间的集成。 GitHub Codespaces允许用户创建安全、可配置、专属的云端开发环境&#xff0c;此集成意味着您可以通过JetBrains Gateway使用在 GitHub Codespaces 中运行喜欢的IDE进行…

VScode搭建Opencv(C++开发环境)

VScode配置Opencv 一、 软件版本二 、下载软件2.1 MinGw下载2.2 Cmake下载2.3 Opencv下载 三、编译3.1 cmake-gui3.2 make3.3 install 四、 VScode配置4.1 launch.json4.2 c_cpp_properties.json4.3 tasks.json 五、测试 一、 软件版本 cmake :cmake-3.27.2-windows-x86_64 Mi…