经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Python » 查看文章
分享一个提高运维效率的 Python 脚本
来源:cnblogs  作者:咸鱼Linux运维  时间:2023/5/10 9:23:54  对本文有异议

哈喽大家好我是咸鱼,今天给大家分享一个能够提升运维效率的 python 脚本

咸鱼平常在工作当中通常会接触到下面类似的场景:

  1. 容灾切换的时候批量对机器上的配置文件内容进行修改替换
  2. 对机器批量替换某个文件中的字段

对于 Linux 机器,咸鱼可以写个 shell 脚本或者直接批量使用 sed 命令就能很好的解决

但对于 Windows 机器,上面的方法就不管用了,我们就需要想其他的办法

这里咸鱼给大家分享一个由 python 编写的脚本,这个脚本能够去替换指定文本文件中的指定内容,而且还能一次替换多个内容

我们先看效果,目标文件:name.txt

  • 修改一个内容
  1. python sed.py c:\name.txt Kanye Edison

  • 修改多个内容
  1. python sed.py c:\name.txt Kanye,male Edison,female


源码在文末哦

首先我们导入模块

  1. import sys
  2. import os
  3. import time
  4. from shutil import copy

然后我们来看一下脚本中的第一个函数——data_preprocess()

  1. def data_preprocess():
  2. file_name, old_str, new_str = sys.argv[1:4] #接收输入的参数:目标文件名,旧内容、新内容、字符编码
  3. try: # 传入字符编码参数
  4. encoding = sys.argv[4]
  5. except IndexError: # 没有传入字符编码参数的话就默认使用 'utf-8' 字符编码
  6. encoding = 'utf-8'
  7. old_str_list = [i.encode(encoding) for i in old_str.split(',')] # 将旧内容转换成列表形式
  8. new_str_list = [i.encode(encoding) for i in new_str.split(',')] # 将新内容转换成列表形式
  9. assert len(old_str_list) == len(new_str_list) # 判断用户输入的 old_str 和 new_str 是不是一一对应
  10. trans_tabs = list(zip(old_str_list, new_str_list)) # 将要旧内容列表(old_str_list)和新内容列表( new_str_list)中的元素一一对应
  11. return file_name, trans_tabs # 返回目标文件名,以及一个旧内容元素和新内容元素一一对应的列表

这个函数实现的功能是接收输入的参数(目标文件名、要替换的内容,替换的内容、字符编码格式),然后将要替换的内容与替换的内容分别转换成列表形式

注意:替换多个内容时在多个内容之间用逗号隔开

例如我们敲如下命令替换一个内容:

  1. python sed.py c:\test.txt Edison Kanye

这个函数就会返回下面内容(由于命令里没有传入字符编码参数,采取默认的 UTF-8)

  1. file_name = c:\test.txt
  2. trans_tabs = [(Edsion, Kanye)]

如果我们需要替换多个内容(例如将首字母改成大写)

  1. python sed.py c:\test.txt edsion,kanye,fish Edsion,Kanye,Fish utf-8

这个函数就会返回下面内容(命令传入了字符编码参数)

  1. file_name = c:\test.txt
  2. trans_tabs = [(edsion, Edsion), (kanye,Kanye), (fish,Fish)]

接下来我们来看第二个函数—— backup()

  1. def backup(file_name):
  2. time_mark = time.strftime('%Y%m%d_%H%M%S') #时间戳
  3. bak_dir = r'C:\Users\Administrator\Desktop' #备份路径
  4. basename = os.path.basename(file_name)
  5. os.makedirs(bak_dir) if not os.path.isdir(bak_dir) else True
  6. copy(file_name, os.path.join(bak_dir, basename + '_' + time_mark))
  7. print("备份 %s 成功" %file_name)

这个函数的功能就是在修改文件之前先把文件备份,防止后期我们需要回滚复原

最后我们来看最后一个函数—— sed()

这个函数便是整个脚本的核心,它负责去执行修改替换文件内容的操作

  1. def sed(file_name, trans_tabs):
  2. with open(file_name + '.swap', 'wb') as swap_fs, open(file_name, 'rb') as file_names: #打开一个临时文件和目标文件
  3. for line in file_names: # 逐行读取
  4. for tab in trans_tabs:
  5. line = line.replace(tab[0], tab[1]) if tab[0] in line else line # 修改替换操作
  6. swap_fs.write(line) # 将修改后的内容写入到临时文件当中
  7. os.remove(file_name) # 删除旧目标文件
  8. os.rename(file_name + '.swap', file_name) # 将临时文件重命名,就变成了新的目标文件

首先先打开一个临时文件(file_name.swap)和目标文件(file_name)

然后对目标文件(file_name)进行逐行读取到内存上,再去对内容进行修改,最后将修改后的内容写入到这个临时文件(file_name.swap)中

修改完毕之后,把临时文件重命名一下、把旧目标文件删掉,这个临时文件就变成了修改内容后的目标文件了

  1. import sys
  2. import os
  3. import time
  4. from shutil import copy
  5. def data_preprocess():
  6. file_name, old_str, new_str = sys.argv[1:4]
  7. try:
  8. encoding = sys.argv[4]
  9. except IndexError:
  10. encoding = 'utf-8'
  11. old_str_list = [i.encode(encoding) for i in old_str.split(',')]
  12. new_str_list = [i.encode(encoding) for i in new_str.split(',')]
  13. assert len(old_str_list) == len(new_str_list)
  14. trans_tabs = list(zip(old_str_list, new_str_list))
  15. return file_name, trans_tabs
  16. def backup(file_name):
  17. time_mark = time.strftime('%Y%m%d_%H%M%S')
  18. bak_dir = r'C:\Users\Administrator\Desktop'
  19. basename = os.path.basename(file_name)
  20. os.makedirs(bak_dir) if not os.path.isdir(bak_dir) else True
  21. copy(file_name, os.path.join(bak_dir, basename + '_' + time_mark))
  22. print("备份 %s" %file_name)
  23. def sed(file_name, trans_tabs):
  24. with open(file_name + '.swap', 'wb') as swap_fs, open(file_name, 'rb') as file_names:
  25. for line in file_names:
  26. for tab in trans_tabs:
  27. line = line.replace(tab[0], tab[1]) if tab[0] in line else line
  28. swap_fs.write(line)
  29. os.remove(file_name)
  30. os.rename(file_name + '.swap', file_name)
  31. file_name, trans_tabs = data_preprocess()
  32. backup(file_name)
  33. sed(file_name, trans_tabs)

原文链接:https://www.cnblogs.com/edisonfish/p/17385866.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号