python备份脚本解析

简介:

 脚本简介:

1)备份源目录的文件

2)目标文件以tar 和bzip2的方式压缩之后放在当前日期文件夹下

4)备份文件以时间注释和执行脚本的用户命名

3)主要用到了时间模块,系统模块,和getpass模块

4)source 可以修改为想备份的目录,因为备份目录一般不经常变动,所以这里写死了

 


 
  1. #!/bin/env python  
  2. #告诉解释器查找pyton解释器并且使用它 
  3. #_*_encoding:utf8_*_  
  4. #指定编码为utf8编码 
  5. import os 
  6. #导入系统模块  
  7. import time 
  8. #导入时间模块  
  9. import getpass 
  10. #导入获取用户模块  
  11. source = ['/oracle/''/oradata/oraInventory']  
  12. #定义备份源目录 
  13. target_dir = '/oradata/backup/' 
  14. #定义备份目标目录  
  15. user = getpass.getuser() 
  16. #定义使用备份脚本的用户  
  17. today = target_dir + time.strftime('%Y%m%d'
  18. #定义今日的日期 
  19. now = time.strftime('%H%M%S'
  20. #定义现在的时间  
  21. comment = raw_input('请输入一个注释 --> ')  
  22. #定义注释为输入的字符串 
  23. if len(comment) == 0
  24. #检查输入的注释是否为空  
  25.     target = today + now + '_' + user + '_' + 'tar.bz2'  
  26. #如果注释为空,备份文件的文件名为日期时间运行脚本用户  
  27. else:  
  28.     target = today +  now + '_' + comment + '_' + user + '_' + 'tar.bz2'  
  29. #如果非空,则使用日期时间注释用户为文件名 
  30. if not os.path.exists(today):  
  31. #检查备份目录下的时间目录是否不存在 
  32.  
  33.     os.mkdir(today)  
  34. #如果不存在创建文件夹 
  35.     print '成功创建文件夹', today  
  36. else:  
  37. #存在,则打印 
  38.     print today,'文件夹已经存在'  
  39. time.sleep(5
  40. #暂停五秒  
  41. zip_command = "tar -cjPf '%s' %s" % (target, ' '.join(source))  
  42. #定义本备份命令 
  43.  
  44. if os.system(zip_command) == 0:  
  45. #使用系统环境(相当于shell执行备份命令,如果成功返回0) 
  46.     print ' 成功备份为:', target  
  47. else:  
  48.     print '备份失败' ,target 






本文转自 珏石头 51CTO博客,原文链接:http://blog.51cto.com/gavinshaw/748115 ,如需转载请自行联系原作者

相关文章
|
1天前
|
存储 弹性计算 运维
每天解析一个脚本(25)
【4月更文挑战第22天】shell脚本解析及训练(25)
22 0
|
1天前
|
存储 运维 监控
每天解析一个脚本(21)
【4月更文挑战第22天】shell脚本解析及训练(21)
7 0
|
1天前
|
存储 运维 Shell
每天解析一个脚本(16)
【4月更文挑战第20天】shell脚本解析及训练(16)
13 2
|
1天前
|
存储 运维 监控
每天解析一个脚本(15)
【4月更文挑战第19天】shell脚本解析及训练(15)
57 1
|
3天前
|
数据采集 机器学习/深度学习 数据挖掘
Python数据清洗与预处理面试题解析
【4月更文挑战第17天】本文介绍了Python数据清洗与预处理在面试中的常见问题,包括Pandas基础操作、异常值处理和特征工程。通过示例代码展示了数据读取、筛选、合并、分组统计、离群点检测、缺失值和重复值处理、特征缩放、编码、转换和降维。强调了易错点,如忽视数据质量检查、盲目处理数据、数据隐私保护、过度简化特征关系和忽视模型输入要求。掌握这些技能和策略将有助于在面试中脱颖而出。
23 8
|
5天前
|
存储 运维 关系型数据库
每天解析一个脚本(十)
【4月更文挑战第18天】shell脚本解析及训练(十)
7 0
|
6天前
|
调度 Python
Python多线程、多进程与协程面试题解析
【4月更文挑战第14天】Python并发编程涉及多线程、多进程和协程。面试中,对这些概念的理解和应用是评估候选人的重要标准。本文介绍了它们的基础知识、常见问题和应对策略。多线程在同一进程中并发执行,多进程通过进程间通信实现并发,协程则使用`asyncio`进行轻量级线程控制。面试常遇到的问题包括并发并行混淆、GIL影响多线程性能、进程间通信不当和协程异步IO理解不清。要掌握并发模型,需明确其适用场景,理解GIL、进程间通信和协程调度机制。
22 0
|
6天前
|
API Python
Python模块化编程:面试题深度解析
【4月更文挑战第14天】了解Python模块化编程对于构建大型项目至关重要,它涉及代码组织、复用和维护。本文深入探讨了模块、包、导入机制、命名空间和作用域等基础概念,并列举了面试中常见的模块导入混乱、不适当星号导入等问题,强调了避免循环依赖、合理使用`__init__.py`以及理解模块作用域的重要性。掌握这些知识将有助于在面试中自信应对模块化编程的相关挑战。
18 0
|
7天前
|
存储 弹性计算 运维
每天解析一个脚本(六)
【4月更文挑战第14天】shell脚本解析及训练(六)
60 0
|
7天前
|
存储 弹性计算 运维
每天解析一个脚本(四)
【4月更文挑战第14天】shell脚本解析及训练(四)
45 1

推荐镜像

更多