Python3實(shí)現(xiàn)配置文件差異對(duì)比腳本
應(yīng)用場(chǎng)景:配置文件由于升級(jí)改動(dòng)了,我們想看看升級(jí)后的配置文件相對(duì)于之前的改動(dòng)了哪些配置項(xiàng)
注意:這個(gè)腳本只能檢測(cè)的配置文件是鍵值對(duì)的形式,就是key=value的形式
我在網(wǎng)上找了好久沒(méi)找到這一塊的案例,大部分都是用一些difflib庫(kù)做的可視化對(duì)比,所以自己嘗試寫了一個(gè)
# 該腳本實(shí)現(xiàn)兩個(gè)配置文件中,新文件相對(duì)于舊文件的增刪改的配置項(xiàng)輸出功能 # 配置文件必須是key = value的形式 import re import sys def data2list(file_stream): """ 生成器 :param file_stream:接收打開的文件對(duì)象 :return: """ for line in file_stream: line = line.strip() if line == "": #過(guò)濾空行 continue line = line.split(" = ") #每行轉(zhuǎn)為列表 line2tuple = tuple(line) #列表轉(zhuǎn)元組 yield line2tuple #每次返回一個(gè)元組 def line_count(keywords, filename): """ :param keywords: 對(duì)比舊文件,在新文件中改變值的鍵名或新增的鍵 :return: 返回鍵所在的行號(hào) :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(): """ 遍歷新文件中的每個(gè)鍵是否在舊文件中存在,如果存在,則比較值是否相同,不相同則打印配置更新,和所在的位置 否則視為在新文件中新增的項(xiàng) :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("配置項(xiàng)值更新:%s=%s-->%s=%s,位置在第%s行" %(k2, dict1[k2],k2, dict2[k2], count)) else: count = line_count(k2,file2) print("新增配置項(xiàng):%s=%s,位置在第%s行" %(k2, dict2[k2], count)) # 新文件中刪除了哪些項(xiàng),在舊文件中有,在新文件中沒(méi)有的項(xiàng) 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) #通過(guò)生成器的具有迭代器特點(diǎn),遍歷來(lái)生成一個(gè)列表,列表中嵌套了數(shù)組,每個(gè)數(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()
測(cè)試結(jié)果如下:
準(zhǔn)備兩個(gè)文件
file1
file2:
運(yùn)行: config_compare.py file1 file2
輸出比較結(jié)果:
配置項(xiàng)值更新:age=19-->age=20,位置在第3行
配置項(xiàng)值更新:gender=man-->gender=female,位置在第4行
配置項(xiàng)值更新:apple=5-->apple=6,位置在第6行
新增配置項(xiàng):peach=2,位置在第9行
新增配置項(xiàng):hello=world,位置在第11行
新增配置項(xiàng):language=english,位置在第12行
新文件中刪除了以下配置:banana=3,位置在舊文件中的第8行
新文件中刪除了以下配置:name=wangtao,位置在舊文件中的第2行
總結(jié)
以上所述是小編給大家介紹的Python3實(shí)現(xiàn)配置文件差異對(duì)比腳本,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
關(guān)于python導(dǎo)入模塊import與常見(jiàn)的模塊詳解
今天小編就為大家分享一篇關(guān)于python導(dǎo)入模塊import與常見(jiàn)的模塊詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-08-08pandas將list數(shù)據(jù)拆分成行或列的實(shí)現(xiàn)
這篇文章主要介紹了pandas將list數(shù)據(jù)拆分成行或列的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12基于python判斷字符串括號(hào)是否閉合{}[]()
這篇文章主要介紹了基于python判斷字符串括號(hào)是否閉合{}[](),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09Python算法中的時(shí)間復(fù)雜度問(wèn)題
時(shí)間復(fù)雜度用于度量算法的計(jì)算工作量,空間復(fù)雜度用于度量算法占用的內(nèi)存空間。這篇文章主要介紹了Python算法中的時(shí)間復(fù)雜度,需要的朋友可以參考下2019-11-11python編寫softmax函數(shù)、交叉熵函數(shù)實(shí)例
這篇文章主要介紹了python編寫softmax函數(shù)、交叉熵函數(shù)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-06-06Python實(shí)現(xiàn)從多表格中隨機(jī)抽取數(shù)據(jù)
這篇文章主要介紹了如何基于Python語(yǔ)言實(shí)現(xiàn)隨機(jī)從大量的Excel表格文件中選取一部分?jǐn)?shù)據(jù),并將全部文件中隨機(jī)獲取的數(shù)據(jù)合并為一個(gè)新的Excel表格文件的方法,希望對(duì)大家有所幫助2023-05-05基于python的BP神經(jīng)網(wǎng)絡(luò)及異或?qū)崿F(xiàn)過(guò)程解析
這篇文章主要介紹了基于python的BP神經(jīng)網(wǎng)絡(luò)及異或?qū)崿F(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09