问题:因为工作中有个特别的需求,我需要每天手动去更新10几个文件夹的SVN,考虑到已经学了一段时间的python,是时候让它发挥一下。通过查资料,编写,调试,已经成功搞定。 下面是思路和代码。
思路:
1. 我用的TortoiseSVN客户端,经过查其帮助手册,发现其支持CMD操作
2. 于是考虑用先将cmd拼凑出来,然后用python的执行命令行的方法来执行。
3. 还要考虑加上些简单的log文件,我放弃使用TortoiseProc提供的log文件,自己写些log生成代码
4. 为了方便后面做变更,将所有可能变更的部分用一个配置文件处理;逻辑处理则用另外一个单独的文件。
5. 因为要运行的脚本的电脑没有python,为了避免麻烦,用pyinstaller生成exe文件,方便运行。
代码:
配置文件:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2018/5/21 10:01
# @Author : PanCheng
# @Site :
# @File : svnconfig.py
# @Software: PyCharm
setting={
'svn':'C:/Program Files/TortoiseSVN/bin/',#svn的程序所在路径
'interval':21600, # 更新时间,单位秒 这里设置6个小时更新一次
'logFile': 'E:/197Backup/logFile.txt', # log文件放置位置
'closeOption': ' /closeonend:1'
}
# /closeonend:0 不自动关闭对话框
# /closeonend:1 如果没发生错误则自动关闭对话框
# /closeonend:2 如果没发生错误和冲突则自动关闭对话框
# /closeonend:3如果没有错误、冲突和合并,会自动关闭
# /closeonend:4如果没有错误、冲突和合并,会自动关闭
dist_lists = [ # 需要更新的folder路径列表
"E:/197Backup/BJFLT/",
"E:/197Backup/BusinessKnowledge/",
"E:/197Backup/CASL/",
"E:/197Backup/CMMIDoc/",
"E:/197Backup/HangCai/",
"E:/197Backup/HangYi/",
"E:/197Backup/HKA/",
"E:/197Backup/HNAIE/",
"E:/197Backup/HR/",
"E:/197Backup/HTMPM/",
"E:/197Backup/ICBCepay/",
"E:/197Backup/PPCS/",
"E:/197Backup/QC/",
"E:/197Backup/QD/",
"E:/197Backup/SEG/",
"E:/197Backup/SZAIR/",
"E:/197Backup/TechnicalTeam/",
"E:/197Backup/TianHangChengBen/",
"E:/197Backup/UE/",
"E:/197Backup/UE_E/"
]
逻辑处理文件:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2018/5/21 9:22
# @Author : PanCheng
# @Site :
# @File : SVNUpdate.py
# @Software: PyCharm
import time,os
from practise.svnconfig import setting, dist_lists
# 全局变量
# 用于存放每次运行update_all_dists期间的logs
logs = []
# 运行命令行需先进入SVN所在的路径
os.chdir(setting['svn'])
# 执行更新并记录更新成功或失败的logs
def update_all_dists():
# 遍历所有需要更新的SVN floders,将更新的cmd拼出来
for dist in dist_lists:
cmd = 'TortoiseProc.exe /command:update /path ' + dist + setting['closeOption']
# 记录下更新的时间
log_time = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime())
log = 'Execute ' + cmd + " --- Time " + log_time + '\n'
logs.append(log)
# 执行更新 (这里后面还需要加上对更新失败的处理)
update_result = os.system(cmd)
# 更新完毕,添加成功与否的log
if update_result == 0:
log = 'SUCCESS: update ' + dist + ' success' + '\n'
else:
log = 'FAIL: update ' + dist + ' fail' + '\n'
logs.append(log)
# 将log写入给定的log file
with open(setting['logFile'], 'a') as f:
logs.append("******************************************************** next update")
for l in logs:
f.write(l)
# 将logs[]清空,为下次循环做准备
logs.clear()
if __name__ == "__main__":
# 每隔一段时间运行一次更新
while True:
update_all_dists()
time.sleep(setting['interval'])
后续需要优化的部分:
对更新失败的处理