根据别人写的方法,对log日志格式做了处理,有需要的可以收下。
点个赞呗。送人玫瑰,手有余香。
下面不多说,送上代码:
#!/usr/bin/python
# -*- coding:utf-8 -*-
import os
import shutil
import sys
import logging
import time
class SynDirTool:
def __init__(self,fromdir,todir):
self.fromdir = fromdir
self.todir = todir
def synDir(self):
return self.__copyDir(self.fromdir,self.todir)
def __copyDir(self,fromdir,todir):
#防止该目录不存在,创建目录
self.__mkdir(todir)
count = 0
for filename in os.listdir(fromdir):
if filename.startswith('.'):
continue
fromfile = fromdir + os.sep + filename
tofile = todir + os.sep + filename
if os.path.isdir(fromfile):
count += self.__copyDir(fromfile,tofile)
else:
count += self.__copyFile(fromfile,tofile)
return count
def __copyFile(self,fromfile,tofile):
if not os.path.exists(tofile) :
shutil.copy2(fromfile,tofile)
logging.info("%s 新增%s ==> %s" % (time.strftime("%Y%m%d-%H:%M:%S"),fromfile,tofile))
return 1
fromstat = os.stat(fromfile)
tostat = os.stat(tofile)
if fromstat.st_ctime > tostat.st_ctime:
shutil.copy2(fromfile,tofile)
logging.info("%s 更新%s ==> %s" % (time.strftime("%Y%m%d-%H:%M:%S"),fromfile,tofile))
return 1
return 0
def __mkdir(self,path):
# 去除首位空格
path=path.strip()
# 去除尾部 \ 符号 或者 /
path=path.rstrip(os.sep)
# 判断路径是否存在
isExists=os.path.exists(path)
# 判断结果
if not isExists:
# 如果不存在则创建目录
logging.info(time.strftime("%Y%m%d-%H:%M:%S")+' '+path+' 目录创建成功')
# 创建目录操作函数
os.makedirs(path)
if __name__ == '__main__':
count = 0
srcdir=sys.argv[1]#获取输入参数1
descdir=sys.argv[2]#获取输入参数2
#logging输出设置
time_stamp = time.strftime("%Y%m%d_%H%M%S")
logging.basicConfig(filename=time_stamp+'.log', level=logging.INFO)
#开始执行SynDirTool工具类
tool = SynDirTool(srcdir,descdir)
count += tool.synDir()