背景:
最近要从SVN 服务器的一个文件夹里面check out 八十几个文件,但是这个文件夹比较大,里面有几千个文件。
由于服务器在印度,check out 非常缓慢而且经常莫名其妙地断开连接。
(吐槽下:谁在维护这个服务器啊,服务器太慢啦,为什么把这么多文件放在同一个文件夹啊)
于是我放弃将整个文件夹check out出来的想法,准备单独check out 这八十几个文件。
平时取单个文件的时候,我是通过浏览器访问SVN服务器,使用浏览器的"文件另存为"功能来下载文件,
但是这八十几个文件一个"另存为",又太... 好吧,我承认我有点懒...
于是我写了这个Python脚本...
核心思想:
使用urllib2模块来模拟浏览器访问SVN服务器.
SVN服务器是要校验权限的,因此使用HTTPBasicAuthHandler来添加用户名和密码,进行授权.
为了维护的方便,将要check out的文件列表放在一个文本文件里面,每一个文件占一行.
将需要check out文件所在文件夹的URL(baseurl),用户名(user),密码(passwd)和存储文件列表的文件名称(fileList)放在配置文件里面.
另外做了几个exception的处理: 文件不存在,用户名 密码 错误 和 URL 错误.
要注意的是 HTTPError 是 URLError 的子集, 因此要先捕获HTTPError, 不然错误总是被URLError 捕获.
代码结构:
|__GetFilesFromSVN.py
|__config.ini
|__fileList.txt
代码&