Skip to content


Subversion导出修订版本范围中修改过的文件

今天在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:

  1. Subversion: Export changed Files in a revision range
  2. 上传工作拷贝中改变的文件
  3. Dreamhost上编译Subversion
  4. Windows编译Subversion简要说明
  5. Bkrpr入门

Posted in subversion. Tagged with , , , , , .

19 Responses

Stay in touch with the conversation, subscribe to the RSS feed for comments on this post.

  1. 々晴天々 said

    呵呵,很厉害啊,昨天才聊到,今天就看到解决方案了。赶紧试试去了

  2. 主要pysvn浪费了不少时间,文档太少了。

  3. 我有用过你这个脚本,发现会丢失版本,具体表现为:我导出版本500-600范围的版本,有些文件明明是在这中间改过的,最终却没有出现在导出的文件列表中。

  4. 补充一下,我的客户端环境为:ubuntu 8.10

  5. 能再具体一点吗?

    我是比较开始和结束的版本,如果你在此之间没有看到某个文件的区别,就不会导出来。

    你可以用svn diff –summarize 看看。

  6. CCG said

    我现在做一个项目,用的这个pysvn,导出指定版本(比如6494-6643)的修改的文件,但是,运行后崩溃了。我只好将原始文件用SVN命令导出,然后,写了个MD5的遍历算法,对比检测。发现用您的这个pysvn导出的文件,有几个MD5和原始文件不同,但是占用空间和字节数却一样!我百思不得其解。
    您有时间的话看看是不是pysvn这个模块的问题。我也很纳闷。

  7. 我试了一下,发现两种方式的文件完全一样,字节数,diff比较都一致

  8. CCG said

    感谢 rocksun。我反复导出不同版本比较各个文件的MD5,发现您的算法没有问题。我的错误判断,耽误您时间了。
    我的那个问题似乎出在压缩解压缩的地方。正在测试。

  9. 今天在用时,发现无法从分支中导出

  10. 具体情况呢?

    bug还是如何?

  11. 报错如下,实际上,该分支是存在的
    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

  12. 貌似我的脚本有些缺陷

    你试试在https://sngo-server/svn/sanguo/branches/v0.7 上执行一下svn log ,看看最后的修订是多少,你在命令行中不要超过13585这个值

  13. 这个版本号已经超过13585了,我试过,在分支中,不管设置这2个版本号为多少都报一样的错,最后一句都类似‘https://sngo-server/svn/sanguo/branches/v0.7′ was not found in the repository at revision xxxxx

  14. 是不是某个较小的版本不存在?

  15. 应该不是,因为我可以确认,我选择的2个版本号,在分支中是存在的。

  16. 请对着路径使用和执行脚本类似的命令执行 svn diff –summarize ,如果报错不一样, 可能是脚本的问题吧

  17. 比较了一下,用命令svn diff -r xxx:xxxx –summarize 会列出一些文件,没报任何错,这样看来应该是脚本有一些缺陷,盼望早日修正,另外 ,感谢你写的脚本。

  18. jack.kam said

    Traceback (most recent call last):
    File “svnchage_export.py”, line 37, in
    raise Exception (“Input URL [targetPath]“)
    Exception: Input URL [targetPath]

    提示这个无法导出…..

  19. 不知道具体情况啊,那个脚本很简单

    你输入的参数错了吧?

Some HTML is OK

(required)

(required, but never shared)

or, reply to this post via trackback.