#! encoding=utf-8

import os
import os.path AllFiles = {}
MinSize = 8100 def OneDir( DirName ):
if DirName[len(DirName)-1] <> "\\":
DirName = DirName + "\\"
tmpFiles = os.listdir( DirName )
for OneFile in tmpFiles:
OneFilePath = DirName + OneFile
if os.path.isdir( DirName + OneFile ):
OneDir( DirName + OneFile + "\\")
else:
statinfo = os.stat( OneFilePath )
if AllFiles.has_key( statinfo.st_size ):
OneKey = AllFiles[ statinfo.st_size ]
OneKey.append( OneFilePath )
AllFiles[ statinfo.st_size ] = OneKey
else:
if statinfo.st_size > MinSize:
# print statinfo.st_size
FileSize = statinfo.st_size
AllFiles[ FileSize ] = [ OneFilePath ]
# print AllFiles
# print AllFiles.keys() import logging # 创建一个logger
logger = logging.getLogger('mylogger')
logger.setLevel(logging.DEBUG) # 创建一个handler,用于写入日志文件
fh = logging.FileHandler('test.log')
fh.setLevel(logging.DEBUG) # 再创建一个handler,用于输出到控制台
ch = logging.StreamHandler()
ch.setLevel(logging.DEBUG) # 定义handler的输出格式
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
fh.setFormatter(formatter)
ch.setFormatter(formatter) # 给logger加入handler
logger.addHandler(fh)
logger.addHandler(ch) # 记录一条日志
#logger.info('foorbar')
#该代码片段来自于: http://www.sharejs.com/codes/python/6248
import pythoncom
from win32com.shell import shell
from win32com.shell import shellcon
def MakeShortcut( lnkname, filename ):
logger.info(lnkname +' is linked to '+filename)
os.remove( lnkname )
shortcut = pythoncom.CoCreateInstance(
shell.CLSID_ShellLink, None,
pythoncom.CLSCTX_INPROC_SERVER, shell.IID_IShellLink)
shortcut.SetPath(filename)
# shortcut.SetIconLocation(iconname,0)#可有可无,没有就默认使用文件本身的图标
# if os.path.splitext(lnkname)[-1] != '.lnk':
lnkname += ".lnk"
shortcut.QueryInterface(pythoncom.IID_IPersistFile).Save(lnkname,0) import filecmp
def FileCompare( SameSizeFiles ):
CompareResult = [[]]*len(SameSizeFiles)
for i in range( 1, len(SameSizeFiles) ):
for j in range( i ):
if filecmp.cmp(SameSizeFiles[i],SameSizeFiles[j]):
if len( CompareResult[ j ] ) > 1:
CompareResult[ j ].append( i )
else:
CompareResult[ j ] = [ i, j ]
break
for i in range( len(SameSizeFiles)-1 ):
if len( CompareResult[ i ] ) > 1:
for j in range( len( CompareResult[ i ] )-1 ):
MakeShortcut( SameSizeFiles[ CompareResult[ i ][j]],
SameSizeFiles[ CompareResult[i][ len( CompareResult[ i ] )-1 ] ] ) ############## start #############
DirList = []
while cmp(input,"#")<>0:
input = raw_input("please input folder names, \"#\" to finish input:")
DirList.append(input)
# print DirList
DirList.pop() for Dir in DirList:
OneDir( Dir ) print AllFiles.keys()
for EachSize in AllFiles.keys():
if (len( AllFiles[EachSize] ) > 1) & ( EachSize > MinSize ):
FileCompare( AllFiles[EachSize] )

singlefile.py的更多相关文章

  1. python调用py中rar的路径问题。

    1.python调用py,在py中的os.getcwd()获取的不是py的路径,可以通过os.path.split(os.path.realpath(__file__))[0]来获取py的路径. 2. ...

  2. Python导入其他文件中的.py文件 即模块

    import sys sys.path.append("路径") import .py文件

  3. import renumber.py in pymol

    cp renumber.py /usr/local/lib/python2.7/dist-packages/pymol import renumber or run /path/to/renumber ...

  4. python gettitle.py

    #!/usr/bin/env python # coding=utf-8 import threading import requests import Queue import sys import ...

  5. 解决 odoo.py: error: option --addons-path: The addons-path 'local-addons/' does not seem to a be a valid Addons Directory!

    情况说明 odoo源文件路径-/odoo-dev/odoo/: 我的模块插件路径 ~/odoo-dev/local-addons/my-module 在my-module中创建了__init__.py ...

  6. caffe机器学习自带图片分类器classify.py实现输出预测结果的概率及caffe的web_demo例子运行实例

    caffe机器学习环境搭建及python接口编译参见我的上一篇博客:机器学习caffe环境搭建--redhat7.1和caffe的python接口编译 1.运行caffe图片分类器python接口 还 ...

  7. 【转】Windows下使用libsvm中的grid.py和easy.py进行参数调优

    libsvm中有进行参数调优的工具grid.py和easy.py可以使用,这些工具可以帮助我们选择更好的参数,减少自己参数选优带来的烦扰. 所需工具:libsvm.gnuplot 本机环境:Windo ...

  8. MySqlNDB使用自带的ndb_setup.py安装集群

    在用Mysql做集群时,使用Mysql的NDB版本更易于集群的扩展,稳定和数据的实时性. 我们可以使用Mysql自带的工具进行集群安装与管理:ndb_setup.py.位于Mysql的安装目录bin下 ...

  9. 将做好的py文件打包成模块,供别人安装调用

    现在要将写完的3个py文件,打包. 步骤: 1.新建一个文件夹setup(名字随便取),在setup文件夹下,再新建一个文件夹financeapi. 2.将上面4个py文件拷贝至financeapi文 ...

随机推荐

  1. TP中U方法详解

    U方法常用于ThinkPHP里的页面跳转 官方称为url组装, 就是根据某种规则组成一个url地址,这个功能就叫组装. 在ThinkPHP里,系统提供了一个封装的函数来处理url的组装,俗称U方法. ...

  2. c# 常用 Common

    /// <summary> /// md5加密字符串 /// </summary> /// <param name="message">< ...

  3. BZOJ 2693: jzptab 莫比乌斯反演 + 积性函数 +筛法

    Code: #include<bits/stdc++.h> #define ll long long #define M 10001000 #define maxn 10200100 #d ...

  4. A6. JVM 垃圾回收算法(GC 算法)

    [概述] 常见的垃圾回收算法有:标记-清除算法.复制算法.标记-整理算法.分代收集算法. [标记-清除算法] 标记-清除算法是最基础的收集算法,如同它的名字一样,算法分为 “标记” 和 “清除” 两个 ...

  5. springBoot启动及发布

    1.在项目编辑器(IDEA)中启动 运行springBoot项目Application类中main方法,这两个按钮都可以.如下图: 当然还有我们配置的启动按钮,这是最常用的启动方式,不再赘述,如下图: ...

  6. numpy.random模块常用函数解析

    numpy.random模块中常用函数解析 numpy.random模块官方文档 1. numpy.random.rand(d0, d1, ..., dn)Create an array of the ...

  7. uWSGI+nginx+django+virtualenv+supervisor部署项目

    一.前言 在部署项目前,你已有一个能够在你本机测试过,能正常启动的Django项目(毕竟本文主要讲解部署Django项目),以及掌握了Linux系统的一些基本命令. 相关链接: Centos7安装py ...

  8. vue 刷新当前页面的时候重新调用新的cookie

    data() { return{ AdminToken: this.getCookie('token'), } }, updated() { //刷新当前页面的时候重新调用新的cookie this. ...

  9. URAL 1108 简单的树形dp背包问题

    题目大意: 一颗苹果树上,每条边都对应了一个权值,最后留下包括root : 1在的含有 m 条边的子树 , 希望留下的子树中权值之和最大 这里保留m条边,我们可以看作是保留了 m + 1 个点 令dp ...

  10. HDU 1542 Atlantics 线段树+离散化扫描

    将 x 轴上的点进行离散化,扫描线沿着 y 轴向上扫描 每次添加一条边不断找到当前状态有效边的长度 , 根据这个长度和下一条边形成的高度差得到一块合法的矩形的面积 #include<iostre ...