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

处理方式就是针对每个文件求其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. ring0 SSDTHook 实现x64/x86

    #include "HookSSDT.h" #include <ntimage.h> #define SEC_IMAGE 0x001000000 ULONG32 __N ...

  2. ring0 进程隐藏实现

    最近在学习内核编程,记录一下最近的学习笔记. 原理:将当前进程从eprocess结构的链表中删除 无法被! process 0 0 看见 #include "HideProcess.h&qu ...

  3. Altium_Designer-如何放置总线

    在绘制原理图时我们避免不了要用到总线,但是在我们使用Altium Designer绘制总线时总是出现一些问题,导致总线无法使用.下面我就来帮助大家绘制出一条的总线,希望能够帮助在这方面摸索的人们. 第 ...

  4. 如何在CRM WebClient UI里使用HANA Live Report

    1. 使用业务角色ANALYTICSPRO登录SAP CRM WebClient UI: 点击新建按钮创建一个新的HANA live report: 类型选择SHL: 弹出窗口,维护report的名称 ...

  5. Nginx+Tomcat+memcached高可用会话保持

    Nginx+Tomcat+memcached高可用会话保持 文章来源dyc2005   一.概述 之前文章已经描述了企业高可用负载相关的架构及实现,其中常用的nginx或haproxy,LVS结合ke ...

  6. 2018.8.2 Juint测试介绍及其命名的规范

    JUnit - 测试框架 什么是 Junit 测试框架? JUnit 是一个回归测试框架,被开发者用于实施对应用程序的单元测试,加快程序编制速度,同时提高编码的质量.JUnit 测试框架能够轻松完成以 ...

  7. autofac 的好博文

    https://www.cnblogs.com/neverc/p/4914091.html#e https://www.cnblogs.com/stulzq/p/8547839.html

  8. svn更改地址怎么办

    开发过程中有时会遇到服务器更换地址的情况,比如之前地址是 svn://www.aaa.com 后来换成了 svn://www.bbb.com 这时候怎么办呢?分客户端和服务器端2种情况处理 客户端: ...

  9. System.TimeDate

    本篇将介绍时间类型. msdn官网:点击查看 时间辅助类:点击查看  方法:计算两个时间的时间差(年月日小时分钟),获取时间戳,时间格式转换,获取时间随机码 定义:表示时间上的一刻,通常以日期和当天的 ...

  10. caffe在 14.04安装

    同事安装遇到的问题,记录一下 需要把cuda里面带的opengl不安装才行,否则冲突.在安装时,首先和之前一样,切换到无图形界面,关掉lightdm,安装cuda时选择--no-opengl-lib, ...