脚本主要用来给游戏客户端做热更的。

处理方式就是针对每个文件求其MD5值,再根据文件的目录和名字对比两个版本的MD5值,如果不一样,则这次热更就需要更新这个文件。

用法很简单。

1,生成MD5码列表

参数有-i,针对某个目录下的指定路径下的所有文件生成MD5的列表。-v 当前版本号多少

2,对比两个路径的文件,并且将不同MD5的文件输出到指定路径下。

参数有-l,-r,-o.

-l就是左边的文件,为比较旧版本的目录。

-r就是右边的文件,为最新版本的目录。

-o就是不同文件的输出目录。

对比会优先查找左边文件夹下是否有.md5,如果有的话,会优先使用文件里的md5记录。

import sys, getopt
import os
import os.path
import hashlib
import shutil searchFolders = ["\\src\\", "\\res\\"] def usage():
print "this is useage" def getmd5(filename, parentName, folderName):
m = hashlib.md5()
mfile = open(filename, 'rb')
m.update(mfile.read())
mfile.close()
md5value = m.hexdigest() #get last part of file name
subStr = filename[len(parentName) - len(folderName):len(filename)]
return md5value+"\t"+ subStr def getCurDir():
path = sys.path[0]
if os.path.isdir(path):
return path
elif os.path.isfile(path):
return os.path.dirname(path) def saveFile(str, ver):
f = open(getCurDir() + "/" + ver + ".md5", 'w')
f.write(str)
f.close() def getDescOfUrl(url):
saveStr = ""
descList = []
index = 0
for parent,dirnames,filenames in os.walk(url):
for filename in filenames:
for i, val in enumerate(searchFolders):
targParent = url + val
if targParent in parent:
fullPath = os.path.join(parent, filename)
md5 = getmd5(fullPath, targParent, val)
#print "file is: " + md5
saveStr = saveStr + md5 + "\n"
descList.append(md5) return saveStr, descList def onIArg(url, ver):
saveStr, descList = getDescOfUrl(url)
saveFile(saveStr, ver) def getDicByFile(url):
file = open(url)
line = f.readline()
retDic = {}
while line:
md5, filename = line.split("\t")
retDic[filename] = md5 return retDic def getDicByUrl(url):
saveStr, splitArr = getDescOfUrl(url)
retDic = {} for value in splitArr:
md5, filename = value.split("\t")
retDic[filename] = md5 return retDic def getDicOfUrl(url):
fileList = os.listdir(url)
version = ""
for value in fileList:
if os.path.splitext(value)[1] == '.md5':
version = os.path.splitext(value)[0]
break if version != "":
return getDicByFile(url + "/" + version + ".md5")
else:
return getDicByUrl(url) opts,args = getopt.getopt(sys.argv[1:], "hi:l:r:v:o:") inputFile = ""
leftFile = ""
rightFile = ""
outFile = ""
version = ""
showHelp = False for op, value in opts:
if op == "-i":
inputFile = value
elif op == "-v":
version = value
elif op == "-l":
leftFile = value
elif op == "-r":
rightFile = value
elif op == "-o":
outFile = value
elif op == "-h":
showHelp = True if showHelp:
usage()
sys.exit()
elif inputFile != "": if version == "":
print "you must input the version value using -v"
sys.exit() onIArg(inputFile, version)
elif leftFile != "":
if rightFile == "":
print "you must input the right file url using -r"
sys.exit()
elif outFile == "":
print "you must input the out direct using -o"
sys.exit()
else:
print "on diff .."
diffDic = {}
leftDic = getDicOfUrl(leftFile)
rightDic = getDicOfUrl(rightFile)
for (filename, md5) in rightDic.items():
if not leftDic.has_key(filename):
diffDic[filename] = True
elif leftDic.get(filename) != md5:
diffDic[filename] = True for (filename, val) in diffDic.items():
#if the folder exit
inUrl = rightFile + filename
outUrl = outFile + filename
folderIndex = outUrl.rfind("\\") outFolder = outUrl[0:folderIndex] if not os.path.isdir(outFolder):
os.makedirs(outFolder) print("copy from " + rightFile + filename)
print("to " + outUrl) shutil.copy(inUrl, outUrl)

脚本里的

searchFolders 是表示获取当前路径下这些子目录的所有文件。可以根据自己项目的情况,自己修改。

一个python的文件对比脚本的更多相关文章

  1. python编写文件统计脚本

    python编写文件统计脚本 思路:用os模块中的一些函数(os.listdir().os.path.isdir().os.path.join().os.path.abspath()等) 实现功能:显 ...

  2. python如何通过windows命令行运行一个python程序文件?

    python如何通过windows命令行运行一个python程序文件? cmd 进入到py文件对应目录下或者直接在上面的文件地址栏输入cmd,敲入回车 定位到对应的目录下 输入python xxx.p ...

  3. 一个python的邮件发送脚本,自动,定时,可以附件发送,抄送,附有说明文件

    #!/bin/env python # -*- coding: utf-8 -*- import datetime import smtplib import os,sys from email.mi ...

  4. 小事牛刀之——python做文件对比

    使用python对比filename1和filenam2的差异,并将差异写入到filename3中. #!/usr/bin/env python # -*- coding: utf-8 -*- # @ ...

  5. Python easyGUI 文件对比 覆盖保存

    #在35-3的基础上进行优化,当用户点击ok按钮的时候,对打开的文件进行检查是否修改.# 如果修改过,则提示覆盖保存.放弃保存.另存为并实现相应的功能 1 import easygui as g im ...

  6. python 将文件描述符包装成文件对象

    有一个对应于操作系统上一个已打开的I/O 通道(比如文件.管道.套接字等)的整型文件描述符,你想将它包装成一个更高层的Python 文件对象. 一个文件描述符和一个打开的普通文件是不一样的.文件描述符 ...

  7. 【Python脚本】Python创建删除文件-----------我的第一个Python脚本

    Python相对C++和Java来说,是解释性语言,非常适合来编写脚本. 很久之前就开始学习Python的语法了,今天写了第一个Python的脚本,来简化我的一些日常工作. 我平时学习的时候喜欢新建一 ...

  8. 编写一个python脚本功能-备份

    版本一 解决方案当我们基本完成程序的设计,我们就可以编写代码了,它是对我们的解决方案的实施.版本一例10.1 备份脚本——版本一 #!/usr/bin/python # Filename: backu ...

  9. (python功能定制)复杂的xml文件对比,产生HTML展示区别

    功能的设计初衷: 处理复杂的xml对比,屏蔽同节点先后顺序的影响 主要涉及知识点: 1.xml解析 ------- ElementTree库 2.文件比对差别 ------- difflib库 3.获 ...

随机推荐

  1. 拼接sql语句时拼接空字符串报sql错误

    先上代码(php): $id_card=""; $sql = "select * from people where id_card=".$id_card; 看 ...

  2. Bloom Filter (海量数据处理)

    什么是Bloom Filter 先来看这样一个爬虫相关问题:文件A中有10亿条URL,每条URL占用64字节,机器的内存限制是4G,现有一个URL,请判断它是否存在于文件A中(爬过的URL无需再爬). ...

  3. 有趣的回文数(Palindrome number)

    文章转自http://blog.163.com/hljmdjlln@126/blog/static/5473620620120412525181/ 做LC上的题"Palindrome num ...

  4. 初识Python(三)

    一.作用域 对于变量的作用域,执行声明并在内存中存在,该变量就可以在后续的代码中使用: 外层变量,可以被内层变量使用:内层变量,也可以被外层变量使用: 如下示例: #!/usr/bin/env pyt ...

  5. ModuleNotFoundError: No module named 'yaml'

    ModuleNotFoundError: No module named 'yaml' 需要安装 pyyaml 包

  6. April 30 2017 Week 18 Sunday

    Our lives stretched out ahead of us, like a perpetual sunrise. 生命如永恒的日出,生生不息. Please respect yoursel ...

  7. IOS 纯代码添加 Button Image Label 添加到自定义View中

    @interface ViewController () /**获取.plist数据*/ @property (nonatomic,strong) NSArray *apps; @end @imple ...

  8. TeamCity实战(2):NuGet服务器

    如果有在内网架设NuGet服务器的需要,比如说公司要求所有开发人员的开发机与外网隔离,但是项目开发又必须要通过NuGet获取开发包的情况. 打开选项其实很简单,但是打开之后怎么样更新开发包要复杂些了. ...

  9. ssd论文解读

    https://www.sohu.com/a/168738025_717210 https://www.cnblogs.com/lillylin/p/6207292.html https://blog ...

  10. Visual Studio Code快捷键_Linux

    Keyboard shortcuts for Linux Basic editing Ctrl + X Cut line(empty selection) Ctrk + C   Copy line(e ...