【说站】python如何判断文件夹内的重复图片
2024-12-29
4
python如何判断文件夹内的重复图片
步骤
1、首先将所有的图片按照图片大小(byte)进行分类,然后再进行分类比较。
2、重复图片很有可能连续出现(因为重复图片大小相同)
如果要判断文件夹中是否有相同的图片,则需要对文件夹中的所有图片进行分类,并逐一判断两张图片是否相同。
如果文件夹中有1000张图片,则第一张图片需要与剩余的999张图片进行比较,第二张图片需要与剩余的998张图片进行比较,第三张图片需要与剩余的997张图片进行比较,以此类推。
实例
if __name__ == '__main__': load_path = 'E:\\测试图片集(未去重)' # 要去重的文件夹 save_path = 'E:\\测试图片集(重复照片)' # 空文件夹,用于存储检测到的重复的照片 os.makedirs(save_path, exist_ok=True) # 获取图片列表 file_map,字典{文件路径filename : 文件大小image_size} file_map = {} image_size = 0 # 遍历filePath下的文件、文件夹(包括子目录) for parent, dirnames, filenames in os.walk(load_path): # for dirname in dirnames: # print('parent is %s, dirname is %s' % (parent, dirname)) for filename in filenames: # print('parent is %s, filename is %s' % (parent, filename)) # print('the full name of the file is %s' % os.path.join(parent, filename)) image_size = os.path.getsize(os.path.join(parent, filename)) file_map.setdefault(os.path.join(parent, filename), image_size) # 获取的图片列表按 文件大小image_size 排序 file_map = sorted(file_map.items(), key=lambda d: d[1], reverse=False) file_list = [] for filename, image_size in file_map: file_list.append(filename) # 取出重复的图片 file_repeat = [] for currIndex, filename in enumerate(file_list): dir_image1 = file_list[currIndex] dir_image2 = file_list[currIndex + 1] result = 比较两张图片是否相同(dir_image1, dir_image2) if(result == "两张图相同"): file_repeat.append(file_list[currIndex + 1]) print("\n相同的图片:", file_list[currIndex], file_list[currIndex + 1]) else: print('\n不同的图片:', file_list[currIndex], file_list[currIndex + 1]) currIndex += 1 if currIndex >= len(file_list)-1: break # 将重复的图片移动到新的文件夹,实现对原文件夹降重 for image in file_repeat: shutil.move(image, save_path) print("正在移除重复照片:", image)
以上就是python判断文件夹内的重复图片的方法,希望对大家有所帮助。更多Python学习指路:python基础教程
本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。
更新于:1天前赞一波!
相关文章
- 【说站】python可变数据类型和不可变数据类型的区别
- 【说站】python引用计数机制的使用
- 【说站】python实例方法中self的作用
- 【说站】Python解释器有哪几种
- 【说站】python变量中self的添加
- 【说站】python不同大小文件的复制方法
- 【说站】python中异步非阻塞如何实现
- 【说站】Python输入三个数用空格隔开
- 【说站】python一行输出10个数
- 【说站】python按行读取文件的方法比较
- 【说站】python打开文件的两种方式
- 【说站】python计算在月球的体重
- 【说站】python如何获取列表的长度
- 【说站】python列表有几种切片形式
- 【说站】python中slice的三个参数
- 【说站】python决策树算法的实现步骤
- 【说站】python决策树算法是什么
- 【说站】python列表缓存的探究
- 【说站】Python中SKlearn是什么
- 【说站】Python findall函数如何匹配字符串
文章评论
评论问答