pysvn client.log() 返回空字典
我有一个脚本,用来从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上。
谢谢,Nash
2 个回答
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'}
8
pysvn.Client.log 方法会返回一个日志条目的列表;每个日志条目都是一个字典。 (可以查看 pysvn 程序员参考)
你可以在代码中这样打印日志信息:
for info in log:
print info.revision.number,
print info.author,
print time.ctime(info.date),
print info.message