今天在QQ群中聊到一个问题,就是导出一个修订版本范围中修改过的文件。其实这是一个常见的需求,例如向客户发布一个补丁。如果是程序员,可以运用diff和patch的方法,但是对于没有编程经验的人来说,最好是直接找到需要提交的文件,并覆盖掉原来的文件。
虽然svn本身没有支持这个功能,但是TortoiseSVN却提供了这个支持,台湾一位朋友写了一个图形教程,我整理了一下转载到了Subversion中文站。另外还有一套Java的解决方案,可以看老外的这个介绍。
不过,我觉得上面两个都还不够好,一个不是脚本,另一个则有点麻烦,于是我自己写了一个类似的脚本,使用python编写,现在做一些简要的说明。脚本可以在http://svn-script.googlecode.com/svn/trunk/tools/svnchanged_export.py下载,运行这个脚本需要python的pysvn包,可以从http://pysvn.tigris.org/servlets/ProjectDocumentList?folderID=1768下载合适的Windows版本,下载后直接安装即可。
使用这个脚本的方式也非常简单,我们就可以直接运行:
python svnchanged_export.py -u username -p password -r 20:HEAD svn://192.168.101.1/lynx/trunk/ xx\yyy
例如上面的命令,用户是username,密码是password,这两个参数可以省略,那样会使用密码缓存或不需要认证。指定的修订版本范围是20到HEAD,对应的URL是 svn://192.168.101.1/lynx/trunk/。导出的文件存放到xx\yyy,默认是当前目录“.”。上面的命令执行后,xx\yy目录下就会出现修订版本HEAD(最新)和修订版本20之间发生过修改的文件,这些文件都存放在原来的相对目录中,修订版本都是最新的。这个命令还可以写为:
python svnchanged_export.py -u username -p password -r 20:90 svn://192.168.101.1/lynx/trunk/ xx\yyy
这时,比较的修订版本变成了90,而对应的输出的文件都是修订版本90的文件。
这个脚本还没有经过实践的检验,只在我的windows下验证过,所以请大家小心使用,如果有问题,可以告诉我,我会尽快解决。你也可以直接加入我建立的这个项目,自己去修改这个脚本。说实话,pysvn的接口虽好,但文档奇缺,我用到一个接口,google没有任何结果。
Related posts:
19 Responses
Stay in touch with the conversation, subscribe to the RSS feed for comments on this post.
呵呵,很厉害啊,昨天才聊到,今天就看到解决方案了。赶紧试试去了
主要pysvn浪费了不少时间,文档太少了。
我有用过你这个脚本,发现会丢失版本,具体表现为:我导出版本500-600范围的版本,有些文件明明是在这中间改过的,最终却没有出现在导出的文件列表中。
补充一下,我的客户端环境为:ubuntu 8.10
能再具体一点吗?
我是比较开始和结束的版本,如果你在此之间没有看到某个文件的区别,就不会导出来。
你可以用svn diff –summarize 看看。
我现在做一个项目,用的这个pysvn,导出指定版本(比如6494-6643)的修改的文件,但是,运行后崩溃了。我只好将原始文件用SVN命令导出,然后,写了个MD5的遍历算法,对比检测。发现用您的这个pysvn导出的文件,有几个MD5和原始文件不同,但是占用空间和字节数却一样!我百思不得其解。
您有时间的话看看是不是pysvn这个模块的问题。我也很纳闷。
我试了一下,发现两种方式的文件完全一样,字节数,diff比较都一致
感谢 rocksun。我反复导出不同版本比较各个文件的MD5,发现您的算法没有问题。我的错误判断,耽误您时间了。
我的那个问题似乎出在压缩解压缩的地方。正在测试。
今天在用时,发现无法从分支中导出
具体情况呢?
bug还是如何?
报错如下,实际上,该分支是存在的
Traceback (most recent call last):
File “/home/grom/tool/svnchanged_export.py”, line 83, in
summary = client.diff_summarize(url, revision_min, url, revision_max)
pysvn._pysvn_2_6.ClientError: ‘https://sngo-server/svn/sanguo/branches/v0.7′ was not found in the repository at revision 13585
貌似我的脚本有些缺陷
你试试在https://sngo-server/svn/sanguo/branches/v0.7 上执行一下svn log ,看看最后的修订是多少,你在命令行中不要超过13585这个值
这个版本号已经超过13585了,我试过,在分支中,不管设置这2个版本号为多少都报一样的错,最后一句都类似‘https://sngo-server/svn/sanguo/branches/v0.7′ was not found in the repository at revision xxxxx
是不是某个较小的版本不存在?
应该不是,因为我可以确认,我选择的2个版本号,在分支中是存在的。
请对着路径使用和执行脚本类似的命令执行 svn diff –summarize ,如果报错不一样, 可能是脚本的问题吧
比较了一下,用命令svn diff -r xxx:xxxx –summarize 会列出一些文件,没报任何错,这样看来应该是脚本有一些缺陷,盼望早日修正,另外 ,感谢你写的脚本。
Traceback (most recent call last):
File “svnchage_export.py”, line 37, in
raise Exception (“Input URL [targetPath]“)
Exception: Input URL [targetPath]
提示这个无法导出…..
不知道具体情况啊,那个脚本很简单
你输入的参数错了吧?