4

我有以下脚本用于从 svn 获取日志消息

import pysvn
class  svncheck(): 
    def __init__(self, svn_root="http://10.11.25.3/svn/Moodle/modules", svn_user=None, svn_password=None):
        self.user = svn_user
        self.password = svn_password
        self.root = svn_root

    def diffrence(self): 
        client = pysvn.Client()
        client.commit_info_style = 1
        client.callback_notify = self.notify
        client.callback_get_login = self.credentials
        log  = client.log(
        self.root, 
        revision_start=pysvn.Revision( pysvn.opt_revision_kind.number, 0),
        revision_end=pysvn.Revision( pysvn.opt_revision_kind.number, 5829),
        discover_changed_paths=True,
        strict_node_history=True,
        limit=0,
        include_merged_revisions=False,
        )
        print log
    def notify( event_dict ):
        print event_dict
        return   

    def credentials(realm, username, may_save):
           return True, self.user, self.password, True



s = svncheck()
s.diffrence()

当我运行此脚本时,它返回一个空字典对象[<PysvnLog ''>, <PysvnLog ''>, <PysvnLog ''>,..

知道我在这里做错了什么吗?我正在使用 pysvn 1.7.2 版再次构建 svn 1.6.5 版欢呼纳什

4

2 回答 2

8

pysvn.Client.log 方法返回日志条目列表;每个日志条目都是一个字典。(见pysvn 程序员参考

您可以像这样在代码中打印日志消息:

for info in log:
    print info.revision.number,
    print info.author,
    print time.ctime(info.date),
    print info.message
于 2010-09-08T03:48:24.040 回答
2

终于让它工作了,似乎我并没有完全理解这个特定的功能是如何工作的,无论如何......我想我会和我的伙伴们分享!

    start_rev = 10
    end_rev = 30
    url = http://dipidi.do.da/svn/foobar
    log_dict = dict((log.revision.number, log["message"]) for log in pysvn.Client().log(url,
                            revision_start=pysvn.Revision( pysvn.opt_revision_kind.number, start_rev ),
                            revision_end=pysvn.Revision( pysvn.opt_revision_kind.number, end_rev ),
                            discover_changed_paths=True,
                            strict_node_history=True,
                            limit=0))
    pprint(log_dict)

如果你不喜欢理解

    for log in pysvn.Client().log(url,
        revision_start=pysvn.Revision( pysvn.opt_revision_kind.number, start_rev ),
        revision_end=pysvn.Revision( pysvn.opt_revision_kind.number, end_rev ),
        discover_changed_paths=True,
        strict_node_history=True,
        limit=0):
    print log.revision.number, log["author"], log["message"]

理解选项给了我以下

    {10: 'testing my commits',
     11: 'whohooo this stuff is fun'}
于 2012-02-23T12:10:12.543 回答