自动对比两个svn版本之间excel文件的差异,并导出成html文件

游戏上线以后, 不定期的会发布一些资源的更新, 其中很多是配置表的修改, 修改的内容有多有少, 如果少量的修改还可以手动通过svn show log的方式对比两个版本之间的文件修改的话,那么一次大剂量的更新, 绝对会让从事diff工作的同学烦躁到爆炸, 说来也巧了, 我就是那个diff同学.

那么闲言碎语就到此为止,先说一下基本步骤:

1. 使用svn diff 命令列出两个版本之间修改过的全部文件,对其中的.xlsx文件(新旧两个版本)使用svn export 命令导出到本地.

2. 调用BeyondCompare执行diff操作

后续如果需要的话可以打包成zip文件,以便发给策划同学核对修改.

so,按照步骤进行说明。

步骤1:

找出svn两个版本之间修改过的文件,可以使用 svn diff 命令,该命令的含义是: 显示两个版本或路径之间的本地修改或差异(Display local changes or differences between two revisions or paths.),当然最好是查看详细的用法描述,可以使用 --help 参数来显示一个命令的详细描述,此处可以输入 svn diff --help 来显示关于diff命令的使用方法和所有参数.

diff命令详细参数

显示出所有修改文件以后,需要用到另一个命令: svn export, 顾名思义就是导出文件. 形式为:

svn export 版本号 要导出文件的url 本地存储路径, 这里只是export命令的一种用法,可以通过查看详细说明来挑选出最适合你需求的用法.

结合 svn diff 和 svn export  就可以把两个版本间修改的内容全部导出到本地,为了后续对比步骤方便操作,建议把两个版本的文件分别放到两个路径下,可以以版本号为文件夹名称,此处以 folder_old 和 folder_new 为名。


步骤2: 

首先, 你要安装了BeyondCompare软件,diff 神器怎么吹都行,

其次, 需要安装一个对比excel文件的工具(应该是一个file format,这里姑且叫工具吧),在BeyondCompare中打开 Tools -> File Formats, 此时可以看到有两个 MS Excel Workbooks,这是因为BeyondCompare自带一个对比excel文件的工具,但是它只能对比excel的第一个sheet页,使用场景受限,所以才需要再安装一个新的对比工具,这个工具可以以文本的方式对比所有的sheet页, 把这个Workbooks设置到另一个的前面.

新安装的workbooks
BeyondCompare自带的workbooks

BeyondCompare提供了一些命令,可以从命令行调用以方便实现自动对比. 可以参考连接 command_line_reference, 里面有详细的参数说明和一些示例. 这里使用script file 的方式进行调用,形式为: exe文件路径  txt文件路径

调用方式

需要新建一txt文件,作为对比时的描述文件,该文件可以设置对比时的一些格式,比如: 文件显示方式是交叉(interleaved)还是并排(side-by-side), 显示全部行(display-all)还是只显示有改动的行(display-mismatches),或者是带上下文的方式(display-context),所有这些设置选项在刚才的命令参考链接里都有列出,可以根据需要选取.

这里采用: 并排显示文件 显示全部行 显示行号 允许单词换行 保存成html文件 使用内置的差异高亮显示方式, 如果参数比较多可以使用 & 符号换行, 所以此处txt文件中内容应该是:

对比参数

上面的 %1 %2 %3 是在命令行调用时传来的参数,在附件中会有全服的批处理文件和txt文件描述,有兴趣的同学可以自行查看。


在步骤1 和 步骤2 执行完毕后,此时应该会生成一些列.htm文件,保存在指定的路径下(此处使用report文件夹),打开其中任一个htm文件,其中显示的对比界面和在BeyondCompare中的界面基本一样,对比内容完全一样。

网页中显示的diff内容

好像不能上传附件,晚些时候再传到其他地方吧.

还有一些需要注意的地方:

1 运行 AutoCompare.bat 文件进行自动对比,双击即可运行,运行给其中的rev_new, rev_old 和 svn_url 三个字段赋值. CompareOperation.bat 和 ExportModifiedFiles.bat 是被调用的批处理文件,不能直接双击运行.

2 源码中diff结束后会生成zip压缩包,由于我的电脑上装的压缩软件是好压,因此使用压缩命令中exe文件路径可能会和你的不同, 如果不需要压缩就直接把相应部分代码注掉即可,如果需要可以根据自己电脑上的压缩软件路径和相关命令进行调用


参考链接:

https://www.scootersoftware.com/v4help/index.html?command_line_reference.html

https://www.scootersoftware.com/support.php?zz=kb_multisheetexcel

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容

  • 命令的使用 1、检出 svn cohttp://路径(目录或文件的全路径)[本地目录全路径] --username...
    小李龍彪阅读 4,418评论 0 9
  • iOS 开发 SVN 版本控制器 更多技术交流请加群 iOS技术联盟 27512466 SVN是Subversio...
    Sunny_Fight阅读 8,739评论 7 63
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,580评论 18 139
  • DevOps和敏捷全栈开发 DevOps的介绍2.DevOps的敏捷开发3.敏捷团队中DevOps的实践过程4.D...
    燕京博士阅读 1,207评论 0 1
  • SVN版本:1.5 及更新版本 名词说明: WC:Working Copy 你的工作区 Versioned:受控的...
    日风和阅读 4,264评论 1 23