首页
python
Win桌面应用自动化pywinauto
pywinauto遍历展示程序的所有菜单项
Python3使用串口
Python字符串处理
Python3实现配置文件差异对比(键值对key=value的形式)
正则
正则匹配两个字符之间的字符串
正则提取markdown中图片链接
正则表达式基本知识
字符串-正则实例
Python生成8位随机字符串的一些方法
python3批量ping检测
python3检测一批主机ip的tcp端口
Python3--DNS
Pyhton3--Win注册表
python远程开机工具
端口的问题以及绑定端口(Python)
python3备份交换机配置
Python-网络
检测到win电脑断网就发出告警声音
Python编写的DNS服务可靠性测试程序
Python编写的TCP/UDP端口探测程序
Python抓包-Pyshark
3D人体骨架检测(mediapipe)
VSCode编辑器
开源IT运维项目
Python3使用snmp获取H3C交换机arp表
Python检测tcp端口状态并发送到企微群
Python3使用smtp发邮件
Python3使用smtp发邮件(带附件)
Python3拉取微软AD域所有用户信息
Python3使用微软AD域账号认证
自动更新公网域名的解析(阿里云)
每日定时推送Excel中排班表信息到企微群
Django
Django模板标签
Django在发送POST请求时返回403错误
Django-mysql数据库条件查询
uwsgi 配置 python virtualenv 虚拟环境目录 ( ini 配置)
常用收藏
python3数据类型转换
python处理文本
txt每行一个字符串_用英文逗号连接
txt_匹配并拆分出需要字符串
python获取日期时间
python执行linux命令的三种方式
python使用ssh连接到linux服务器执行命令
本文档由 内网文摘 发布,转载请注明出处
-
+
home page
Python3实现配置文件差异对比(键值对key=value的形式)
网上大部分都是用一些difflib库做的可视化对比 这个脚本只能检测的配置文件是键值对的形式,就是key=value的形式 config_compare.py ```python # 该脚本实现两个配置文件中,新文件相对于旧文件的增删改的配置项输出功能 # 配置文件必须是key = value的形式 import re import sys def data2list(file_stream): """ 生成器 :param file_stream:接收打开的文件对象 :return: """ for line in file_stream: line = line.strip() if line == "": #过滤空行 continue line = line.split(" = ") #每行转为列表 line2tuple = tuple(line) #列表转元组 yield line2tuple #每次返回一个元组 def line_count(keywords, filename): """ :param keywords: 对比旧文件,在新文件中改变值的键名或新增的键 :return: 返回键所在的行号 :filename 文件名称 """ count = 1 with open(filename) as fp: for line in fp: line = line.strip() if re.search(keywords, line): return count count += 1 #比较新文件中配置型值改变的和新增的配置 def compare_config(): """ 遍历新文件中的每个键是否在旧文件中存在,如果存在,则比较值是否相同,不相同则打印配置更新,和所在的位置 否则视为在新文件中新增的项 :return: """ global dict1,dict2 for k2 in dict2.keys(): k1 = list(dict1.keys()) if k2 in k1: if dict2[k2] != dict1[k2]: count = line_count(k2, file2) print("配置项值更新:%s=%s-->%s=%s,位置在第%s行" %(k2, dict1[k2],k2, dict2[k2], count)) else: count = line_count(k2,file2) print("新增配置项:%s=%s,位置在第%s行" %(k2, dict2[k2], count)) # 新文件中删除了哪些项,在旧文件中有,在新文件中没有的项 set1 = set(dict1.keys()) set2 = set(dict2.keys()) deleteKeys = set1 - set2 for k1 in deleteKeys: count = line_count(k1, file1) print("新文件中删除了以下配置:%s=%s,位置在旧文件中的第%s行" %(k1, dict1[k1],count)) if __name__ == '__main__': try: file1 = sys.argv[1] file2 = sys.argv[2] except: print("userage:xxx.py oldfile newfile") sys.exit(1) fp1 = open(file1) fp2 = open(file2) #通过生成器的具有迭代器特点,遍历来生成一个列表,列表中嵌套了数组,每个数组里面村了每行的数据 gen1 = data2list(fp1) list1 = [] for i in gen1: list1.append(i) dict1 = dict(list1) # dict函数可以把列表中嵌套的元组转为字典 gen2 = data2list(fp2) list2 = [] for i in gen2: list2.append(i) dict2 = dict(list2) fp1.close() fp2.close() compare_config() ``` 待对比的文件 file1 ``` name = zhangsan age = 18 language = en ``` file2 ``` name = zhangsan age = 19 hello = world ``` 运行: `config_compare.py file1 file2` 输出比较结果: ``` 配置项值更新:age=18-->age=19,位置在第2行 新增配置项:hello=world,位置在第3行 新文件中删除了以下配置:language=en,位置在旧文件中的第3行 ``` 原文链接:https://www.jb51.net/article/174420.htm
local
Sept. 27, 2021, 11:42 a.m.
Share documents
Collection documents
Last
Next
Scan wechat
Copy link
Scan your mobile phone to share
Copy link
关于 LocalNetwork
LocalNetwork
是由mrdoc开源
LocalNetwork.cn
修改的在线文档系统,作为个人和小型团队的云笔记、文档和知识库管理工具。
如果此文档给你或你的团队带来了帮助,欢迎支持作者持续投入精力更新和维护!内网文摘 & LocalNetwork
>>>主页
logo
logo
Download markdown file
share
link
type
password
Update password