Python3實現(xiàn)配置文件差異對比腳本
應(yīng)用場景:配置文件由于升級改動了,我們想看看升級后的配置文件相對于之前的改動了哪些配置項
注意:這個腳本只能檢測的配置文件是鍵值對的形式,就是key=value的形式
我在網(wǎng)上找了好久沒找到這一塊的案例,大部分都是用一些difflib庫做的可視化對比,所以自己嘗試寫了一個
# 該腳本實現(xiàn)兩個配置文件中,新文件相對于舊文件的增刪改的配置項輸出功能 # 配置文件必須是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(" = ") #每行轉(zhuǎn)為列表 line2tuple = tuple(line) #列表轉(zhuǎn)元組 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) #通過生成器的具有迭代器特點,遍歷來生成一個列表,列表中嵌套了數(shù)組,每個數(shù)組里面村了每行的數(shù)據(jù) gen1 = data2list(fp1) list1 = [] for i in gen1: list1.append(i) dict1 = dict(list1) # dict函數(shù)可以把列表中嵌套的元組轉(zhuǎn)為字典 gen2 = data2list(fp2) list2 = [] for i in gen2: list2.append(i) dict2 = dict(list2) fp1.close() fp2.close() compare_config()
測試結(jié)果如下:
準備兩個文件
file1
file2:
運行: config_compare.py file1 file2
輸出比較結(jié)果:
配置項值更新:age=19-->age=20,位置在第3行
配置項值更新:gender=man-->gender=female,位置在第4行
配置項值更新:apple=5-->apple=6,位置在第6行
新增配置項:peach=2,位置在第9行
新增配置項:hello=world,位置在第11行
新增配置項:language=english,位置在第12行
新文件中刪除了以下配置:banana=3,位置在舊文件中的第8行
新文件中刪除了以下配置:name=wangtao,位置在舊文件中的第2行
總結(jié)
以上所述是小編給大家介紹的Python3實現(xiàn)配置文件差異對比腳本,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
關(guān)于python導(dǎo)入模塊import與常見的模塊詳解
今天小編就為大家分享一篇關(guān)于python導(dǎo)入模塊import與常見的模塊詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08pandas將list數(shù)據(jù)拆分成行或列的實現(xiàn)
這篇文章主要介紹了pandas將list數(shù)據(jù)拆分成行或列的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12python編寫softmax函數(shù)、交叉熵函數(shù)實例
這篇文章主要介紹了python編寫softmax函數(shù)、交叉熵函數(shù)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06Python實現(xiàn)從多表格中隨機抽取數(shù)據(jù)
這篇文章主要介紹了如何基于Python語言實現(xiàn)隨機從大量的Excel表格文件中選取一部分數(shù)據(jù),并將全部文件中隨機獲取的數(shù)據(jù)合并為一個新的Excel表格文件的方法,希望對大家有所幫助2023-05-05基于python的BP神經(jīng)網(wǎng)絡(luò)及異或?qū)崿F(xiàn)過程解析
這篇文章主要介紹了基于python的BP神經(jīng)網(wǎng)絡(luò)及異或?qū)崿F(xiàn)過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-09-09