分享一个提高运维效率的 Python 脚本

yizhihongxing

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

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

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

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

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

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

我们先看效果,目标文件:name.txt
分享一个提高运维效率的 Python 脚本

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

分享一个提高运维效率的 Python 脚本

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

分享一个提高运维效率的 Python 脚本
源码在文末哦

首先我们导入模块

import sys
import os
import time
from shutil import copy

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

def data_preprocess():
    file_name, old_str, new_str = sys.argv[1:4] #接收输入的参数:目标文件名,旧内容、新内容、字符编码
    try: # 传入字符编码参数
        encoding = sys.argv[4] 
    except IndexError: # 没有传入字符编码参数的话就默认使用 'utf-8' 字符编码
        encoding = 'utf-8' 

    old_str_list = [i.encode(encoding) for i in old_str.split(',')] # 将旧内容转换成列表形式
    new_str_list = [i.encode(encoding) for i in new_str.split(',')] # 将新内容转换成列表形式

    assert len(old_str_list) == len(new_str_list) # 判断用户输入的 old_str 和 new_str 是不是一一对应
    trans_tabs = list(zip(old_str_list, new_str_list)) # 将要旧内容列表(old_str_list)和新内容列表( new_str_list)中的元素一一对应

    return file_name, trans_tabs # 返回目标文件名,以及一个旧内容元素和新内容元素一一对应的列表

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

import sys
import os
import time
from shutil import copy


def data_preprocess():
    file_name, old_str, new_str = sys.argv[1:4]
    try:
        encoding = sys.argv[4]
    except IndexError:
        encoding = 'utf-8'

    old_str_list = [i.encode(encoding) for i in old_str.split(',')]
    new_str_list = [i.encode(encoding) for i in new_str.split(',')]

    assert len(old_str_list) == len(new_str_list)
    trans_tabs = list(zip(old_str_list, new_str_list))

    return file_name, trans_tabs


def backup(file_name):
    time_mark = time.strftime('%Y%m%d_%H%M%S')
    bak_dir = r'C:\Users\Administrator\Desktop'
    basename = os.path.basename(file_name)
    os.makedirs(bak_dir) if not os.path.isdir(bak_dir) else True
    copy(file_name, os.path.join(bak_dir, basename + '_' + time_mark))
    print("备份 %s" %file_name)


def sed(file_name, trans_tabs):
    with open(file_name + '.swap', 'wb') as swap_fs, open(file_name, 'rb') as file_names:
        for line in file_names:
            for tab in trans_tabs:
                line = line.replace(tab[0], tab[1]) if tab[0] in line else line
            swap_fs.write(line)
    os.remove(file_name)
    os.rename(file_name + '.swap', file_name)


file_name, trans_tabs = data_preprocess()
backup(file_name)
sed(file_name, trans_tabs)

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

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:分享一个提高运维效率的 Python 脚本 - Python技术站

(0)
上一篇 2023年5月9日
下一篇 2023年5月10日

相关文章

  • Python常用模块之threading和Thread模块及线程通信

    Python常用模块之threading和Thread模块及线程通信 简介 Python中可以使用Thread模块和threading模块来创建线程。其中Thread模块是低级模块,用于低级别的线程控制,而threading模块是高级模块,对Thread模块进行了封装,使得线程更加方便使用。本文将对这两个模块进行详细讲解,并讨论线程之间是如何进行通信的。 基…

    python 2023年5月19日
    00
  • 利用Python和OpenCV库将URL转换为OpenCV格式的方法

    首先,将URL转换为OpenCV格式需要经历以下过程: 使用Python的requests库从URL获取数据; 将获取到的数据进行解码; 将解码得到的数据转换为OpenCV格式。 下面是具体的步骤和示例说明: 步骤一:使用Python的requests库从URL获取数据 在Python中,可以通过requests库来发送HTTP请求,从而获取到URL对应资源…

    python 2023年6月3日
    00
  • Python中asyncore的用法实例

    下面是关于“Python中asyncore的用法实例”的完整攻略: 一、asyncore库的介绍 在介绍asyncore的用法之前,先来了解一下asyncore库的概念。asyncore是Python的一个标准库,其目的是为了方便的实现基于事件驱动的网络编程。asyncore是基于SocketServer.py、呈现异步方式的socket支持并发操作。 二、…

    python 2023年5月19日
    00
  • Python中的迭代器与生成器高级用法解析

    Python中的迭代器与生成器高级用法解析 迭代器 什么是迭代器 在Python中,任何一个对象,如果它定义了__iter__方法和__next__方法,那么它就被称为是一个迭代器。 __iter__方法返回一个迭代器对象本身,__next__方法返回迭代器对象的下一个元素。 迭代器的高级用法 itertools模块 Python的itertools模块提供…

    python 2023年6月3日
    00
  • Python json 错误xx is not JSON serializable解决办法

    当在Python中使用json.dumps()或json.dump()函数将对象或数据结构转化为JSON字符串时,有时会遇到报错xx is not JSON serializable的问题,这是由于Python数据结构中,某些数据类型无法被直接序列化为JSON格式,例如 datetime.datetime、bytes、set等Python所独有的数据结构。本…

    python 2023年6月3日
    00
  • 如何在Python中使用peewee ORM操作数据库?

    如何在Python中使用peewee ORM操作数据库? Peewee是一个轻量级的Python ORM(对象关系映射)库,它提供了一种简单的方式来操作关系型数据库。使用Peewee,我们可以使用Python代码来创建、读取、更新删除关系型数据库中的数据。以下是如何在Python中使用Peewee ORM操作数据库的完整使用攻略,包括连接数据库、创建表、插入…

    python 2023年5月12日
    00
  • 详解python百行有效代码实现汉诺塔小游戏(简约版)

    详解Python百行有效代码实现汉诺塔小游戏(简约版) 本文介绍一个Python实现汉诺塔小游戏的代码,只需100行左右,包含了注释和测试代码。该代码实现了汉诺塔小游戏的完整功能,包括打印提示信息、输入和校验用户输入、移动棋子和胜利条件判断等。 汉诺塔小游戏介绍 汉诺塔(Tower of Hanoi)是一个古老的数学问题,通常有三个柱子和一些圆盘,每个圆盘都…

    python 2023年5月19日
    00
  • Python reversed()改变顺序

    当我们使用Python语言进行编程时,经常需要对一个序列进行逆序操作。Python提供了一个非常方便的方法:reversed()函数。在本篇文章中,我们将详细讲解Python reversed()函数的使用方法。 reversed()函数基本用法 reversed()函数用于将序列进行逆序操作,返回一个新的序列。它可以接收实参为序列,如字符串、列表、元组等。…

    python-answer 2023年3月25日
    00
合作推广
合作推广
分享本页
返回顶部