python 清理文件名不同的相同文件

#!/usr/bin/python  
#coding:utf8

import sys
import filecmp
import os
import hashlib

allrootpath = [
    "D:\\360down\\now",
    "F:\\pl",
    "C:\\newgif",
    "H:\games\\newdoc\\360down",
]

all_types = [".rar", ".gif", ".zip", ".jpg", ".png"]

allfiles = []

runforall = False

def is_valid_type(filepath):
    #valid_types = all_types
    valid_types = [".gif"]
    re = False
    for types in valid_types:
        if filepath.find(types) > -1:
            re = True
            break
    return re

def CalcMD5(filepath):
    with open(filepath,'rb') as f:
        md5obj = hashlib.md5()
        md5obj.update(f.read())
        hash = md5obj.hexdigest()
        return hash

def traverseDirByOSWalk(path):
    global allfiles
    path = os.path.expanduser(path)
    for (dirname, subdir, subfile) in os.walk(path):
        for f in subfile:
            fullfile = os.path.join(dirname, f)
            if runforall or is_valid_type(fullfile):
                allfiles.append(fullfile)

def dirlist(path, allfile):  
    filelist =  os.listdir(path)  
  
    for filename in filelist:  
        filepath = os.path.join(path, filename)  
        if os.path.isdir(filepath):  
            dirlist(filepath, allfile)  
        else:  
            allfile.append(filepath)  
    return allfile

for rootpath in allrootpath:
    traverseDirByOSWalk(rootpath)

print len(allfiles)

fileMd5Dir = {}

counter = 0

for file in allfiles:
    code = CalcMD5(file)
    if fileMd5Dir.has_key(code) == False:
        fileMd5Dir[code] = []
        fileMd5Dir[code].append(file)
    else:
        isExist = False
        for existFile in fileMd5Dir[code]:
            if filecmp.cmp(existFile, file) == True:
                isExist = True
                break
        if isExist == True:
            os.remove(file)
            print "Delete " + file + " !!!"
            counter = counter + 1
            print counter
        else:
            fileMd5Dir[code].append(file)

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值