python实现定时自动备份文件到其他主机的实例代码
作者:lzhh 发布时间:2023-04-26 09:30:52
标签:python,备份文件
定时将源文件或目录使用WinRAR压缩并自动备份到本地或网络上的主机
1.确保WinRAR安装在默认路径或者把WinRAR.exe添加到环境变量中
2.在代码里的sources填写备份的文件或目录,target_dir填写备份目的目录
3.delete_source_file为备份完后是否删除源文件(不删除子文件夹)
4.备份成功/失败后生成备份日志
按照格式,填写源目的:
sources = [r'E:\目录1', r'E:\目录2\b.txt'] #例:= [ r'E:\test\1234.txt', r'E:\test1']
target_dir = r'\\10.1.5.227\共享\备份' #例:= r'D:\备份' 或 = r'\\10.1.5.227\共享目录'
delete_source_file = False #False/True
手动运行三次,已经有两个备份zip了
打开log查看为什么少了一个
可以看到目录1备份失败了,细看发现,目录1下的a.txt没有权限(读取),是因为用户对该文件没有权限。
如果该目录或者子目录下有一个没有权限,会导致整个目录都不能备份, 日志看到a.txt没有权限.
第二次备份的时候将源文件删除后,第三次备份就没有文件备份了
接下来将脚本程序添加到win的计划任务里,就能实现定时自动备份辣<( ̄︶ ̄)>
把代码文件添加进来,同时也可以在这里添加参数-d, 指明备份完后删除源文件
完整代码
python3.0
# -*- coding=utf-8 -*-
#进行了一场py/etherchannel
import os, sys
import time
import logging
sources = [r'E:\视频笔记', r'E:\目录\b.txt'] #例:= [ r'E:\test\1234.txt', r'E:\test1']
target_dir = r'\\10.1.5.227\共享\备份' #例:= r'D:\备份' 或 = r'\\10.1.5.227\共享目录'
delete_source_file = False #False/True
def Init_Logging(path):
logging.basicConfig(level=logging.INFO,
format='%(asctime)s %(levelname)-8s %(message)s',
filename=path + '\\' + 'log.txt',
filemode='a',
datefmt='%Y-%m-%d %X')
def Ctypes(message, title):
import ctypes
ctypes.windll.user32.MessageBoxA(0,message.encode('gb2312'), \
title.encode('gb2312'),0)
sys.exit()
def Check_Dir_Permit(dirs, dirc_permit=True, root=''):
for dirc in dirs:
dirc = os.path.join(root,dirc)
try:
os.chdir(dirc)
except IOError as e:
logging.error("找不到指定文件或没有权限 >>> " + str(e))
dirc_permit = False
return dirc_permit
def Create_Directory(dir):
if not os.path.exists(dir):
try:
os.mkdir(dir)
print('Successfully created directory',dir)
except IOError as e:
Ctypes(u"target_dir 目录路径不存在 ", u' 错误')
assert Check_Dir_Permit([dir]), Ctypes(u"target_dir 没有权限 ", u' 错误')
return dir
def Check_File_Permit(files, file_permit=True, root=''):
for filename in files:
file = os.path.join(root,filename)
try:
f = open(file)
f.close()
except IOError as e:
logging.error("找不到指定文件或没有权限 >>> " + str(e))
file_permit = False
return file_permit
def Permit_Source(sources):
allow_sources = []
disallow_sources = []
for source in sources:
file_permit = True
dirc_permit = True
for (root, dirs, files) in os.walk(source):
file_permit = Check_File_Permit(files, file_permit,root=root)
dirc_permit = Check_Dir_Permit(dirs, dirc_permit,root=root)
if os.path.isdir(source) and file_permit and dirc_permit or \
os.path.isfile(source) and Check_File_Permit([source], file_permit):
allow_sources.append(source)
else:
disallow_sources.append(source)
return (allow_sources,disallow_sources)
def Delete_Files(allow_sources):
for source in allow_sources:
if os.path.isdir(source):
command = 'del /a/s/f/q ' + source #/s:也把子文件夹的文件一并删除
if os.system(command) == 0:
logging.info('del: ' + str(source))
else:
logging.error(str(source) + ' 删除失败')
else:
command = 'del /a/f/q ' + source
if os.system(command) == 0:
logging.info('del: ' + str(source))
else:
logging.error(str(source) + ' 删除失败')
def Compress_Backup(target, source):
target = target + '\\' + time.strftime('%Y%m%d%H%M%S') + '.rar'
if os.path.exists(r"C:\Program Files (x86)\WinRAR\WinRAR.exe"):
rar_command = r'"C:\Program Files (x86)\WinRAR\WinRAR.exe" A %s %s' % (target,' '.join(source)) #WinRAR.exe" A %s %s -r'加上-r是作用到子文件夹中同名的文件
else:
rar_command = 'WinRAR' + ' A %s %s' % (target,' '.join(source))
if os.system(rar_command) == 0:
print('Successful backup to', target)
logging.info(str(source) + ' 备份到 ' + str(target) + ' 成功')
try:
if delete_source_file or sys.argv[1] == '-d':
Delete_Files(source)
except IndexError:
pass
else:
logging.error("备份失败:WinRAR出错,确认路径 或 压缩被中断")
Ctypes(u"备份失败:WinRAR出错,确认路径 或 压缩被中断", u' 错误')
if __name__ == '__main__':
target_dir = Create_Directory(target_dir)
Init_Logging(target_dir)
logging.info('=' * 80)
allow_sources, disallow_sources = Permit_Source(sources)
if allow_sources:
Compress_Backup(target_dir, allow_sources)
if disallow_sources:
print(disallow_sources, ' 备份失败')
logging.error(str(disallow_sources) + ' 备份失败')
总结
以上所述是小编给大家介绍的python实现定时自动备份文件到其他主机的实例代码网站的支持!
来源:https://www.cnblogs.com/etherchannel/archive/2018/02/23/8460825.html
0
投稿
猜你喜欢
- DataFrame是一个组织成命名列的数据集。它在概念上等同于关系数据库中的表或R/Python中的数据框架,但其经过了优化。DataFra
- python中获取字典的key列表和value列表 # -*- coding: utf-8 -*-# 定义一个字典dic = {'剧
- hello,我是小小炽,这是我写的第一篇博客,写博客一直都想在写,但是苦于能力尚浅,在各位大牛面前那既然是关公面前耍大刀了,但是其实想来每一
- 本文实例讲述了MySQL中使用replace、regexp进行正则表达式替换的用法。分享给大家供大家参考,具体如下:今天一个朋友问我,如果将
- 这篇文章主要介绍了python连接字符串过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以
- 以用户为中心的设计、用户体验,这两个词现在在互联网上几乎随处可见,除了设计师外,很多的用户也都在说这两个词,于是我们经常会听到诸如“这里用户
- 前言本文给大家详细介绍了解决php-fpm.service not found问题的相关内容,文中介绍的非常详细,下面来一起看看详细的介绍:
- 第一步:下载和安装python-3.4.4amd.msi可以去官方网站下载,也可以从网盘下载: 链接: https://pan.baidu.
- 前言之前简单学习过python爬虫基础知识,并且用过scrapy框架爬取数据,都是直接能用xpath定位到目标区域然后爬取。可这次碰到的需求
- 本文实例讲述了JS实现基于Sketch.js模拟成群游动的蝌蚪运动动画效果。分享给大家供大家参考,具体如下:基于Sketch.js,实现了物
- 这里我们通过请求网页例子来一步步理解爬虫性能当我们有一个列表存放了一些url需要我们获取相关数据,我们首先想到的是循环简单的循环串行这一种方
- 今天来研究python中moviepy模块的用途近来有大量处理视频的需求,常会碰到一个问题是下载的视频音量过小,会需要将它调大声,虽然有在线
- 本文主要涉及图形验证码的相关功能,主要包括,图形验证码获取、验证码文字存储、验证码生成等。图形验证码接口设计和定义 验证码获取接口
- 前言在使用 Go 语言开发过程中,我们不免会定义结构体,但是我们定义的结构体都是有字段的,基本不会定义不包含字段的 空结构体。你可能会反过来
- Go 在testing包中内置测试命令go test,提供了最小化但完整的测试体验。标准工具链还包括基准测试和基于代码覆盖的语句,类似于NC
- Microsoft SQL Server 7.0安全问题Microsoft Corporation【「Microsoft SQL Serve
- concat()是将tensor沿着指定维度连接起来。其中tensorflow1.3版中是这样定义的:concat(values,axis,
- vsCode是什么Visual Studio Code (简称 VS Code / VSC) 是一款免费开源的现代化轻量级代码编辑器,支持几
- 当你在IE中点击一个Realplayer连接时,系统会自动启动Realplayer软件,不仅占用系统内存,而且在上网时Realplayer容
- ERROR 1819 (HY000): Your password does not satisfy the current policy