Python自動(dòng)化運(yùn)維_文件內(nèi)容差異對(duì)比分析
模塊:difflib
安裝:Python版本大于等于2.3系統(tǒng)自帶
功能:對(duì)比文本之間的差異,而且支持輸出可讀性比較強(qiáng)的HTML文檔,與Linux中的diff命令比較相似。
兩個(gè)字符串的差異對(duì)比:
#import difflib #text1=''' #hello world. #how are you. #nice to meet you. #''' #text1_lines=text1.splitlines() # 以行進(jìn)行分割,便于進(jìn)行對(duì)比 #text2=''' #Hello World. #how are you! #Nice to meet you~ #''' #text2_lines=text2.splitlines() # 以行進(jìn)行分割,便于進(jìn)行對(duì)比 #dif1=difflib.Differ() # 創(chuàng)建Differ() 對(duì)象 #diff1=dif1.compare(text1_lines,text2_lines) # 采用compare() 方法對(duì)字符串進(jìn)行比較 #print('\n'.join(list(diff1)))
此外difflib 還有SequenceMatcher()類,此類支持任意類型序列的比較;還有HtmlDiff() 類,此類支持將比較結(jié)果以HTML格式輸出。
符號(hào)含義說(shuō)明:
符號(hào)
含義
'-'
包含在第一個(gè)序列行中,但不包含在第二個(gè)序列行
'+'
包含在第二個(gè)序列行中,但不包含在第一個(gè)序列行
' '
兩個(gè)序列行一致
'?'
標(biāo)志兩個(gè)序列行存在增量差異
'^'
標(biāo)志出兩個(gè)序列行存在的差異字符
生成HTML格式文檔:
#import difflib #text1=''' #hello world. #how are you. #nice to meet you. #''' #text1_lines=text1.splitlines() # 以行進(jìn)行分割,便于進(jìn)行對(duì)比 #text2=''' #Hello World. #how are you! #Nice to meet you~ #''' #text2_lines=text2.splitlines() # 以行進(jìn)行分割,便于進(jìn)行對(duì)比 #d=difflib.HtmlDiff() #print(d.make_file(text1_lines,text2_lines)) # 之后使生成的文件變?yōu)?.html即可使用瀏覽器查看
對(duì)比配置文件差異:
#import difflib #import os #try: # textfile1=sys.argv[1] # 第1個(gè)配置文件路徑參數(shù) # textfile2=sys.argv[2] # 第2個(gè)配置文件路徑參數(shù) #except Exception,e: # print('Error:'+str(e)) # print('使用:腳本名.py filename1 filename2') # sys.exit() #def readfile(filename): # 文件讀取分隔函數(shù) # try: # fileHandle=open(filename,'rb') # text=fileHandle.read().splitlines() # 讀取后按行進(jìn)行分隔 # fileHandle.close() # return text # except IOError as error: # print('讀取文件錯(cuò)誤:'+str(error)) # sys.exit() #if textfile1=='or textfile2==': # print('使用:腳本名.py filename1 filename2') # sys.exit() #text1_lines=readfile(textfile1) # 調(diào)用readfile獲取分隔后的字符串 #text2_lines=readfile(textfile2) #d=difflib.HtmlDiff() # 創(chuàng)建HtmlDiff() 類對(duì)象 #print(d.make_file(text1_lines,text2_lines)) # 通過(guò)make_file() 方法輸出HTML格式的結(jié)果
以上這篇Python自動(dòng)化運(yùn)維_文件內(nèi)容差異對(duì)比分析就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- python使用dabl幾行代碼實(shí)現(xiàn)數(shù)據(jù)處理分析及ML自動(dòng)化
- Python利用Charles 實(shí)現(xiàn)全部自動(dòng)答題思路流程分析
- Biblibili視頻投稿接口分析并以Python實(shí)現(xiàn)自動(dòng)投稿功能
- Python實(shí)現(xiàn)自動(dòng)裝機(jī)功能案例分析
- Python + Requests + Unittest接口自動(dòng)化測(cè)試實(shí)例分析
- python自動(dòng)化測(cè)試之異常及日志操作實(shí)例分析
- python自動(dòng)化工具日志查詢分析腳本代碼實(shí)現(xiàn)
- ?分享4款Python 自動(dòng)數(shù)據(jù)分析神器
相關(guān)文章
Python實(shí)現(xiàn)短網(wǎng)址ShortUrl的Hash運(yùn)算實(shí)例講解
這篇文章主要介紹了Python實(shí)現(xiàn)短網(wǎng)址ShortUrl的Hash運(yùn)算,較為詳細(xì)的分析了Python短網(wǎng)址運(yùn)算的算法原理與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2015-08-08python代碼實(shí)現(xiàn)ID3決策樹(shù)算法
這篇文章主要為大家詳細(xì)介紹了python代碼實(shí)現(xiàn)ID3決策樹(shù)算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12Python通過(guò)UDP傳輸超過(guò)64k的信息
在UDP中,單個(gè)數(shù)據(jù)包的最大尺寸通常受到網(wǎng)絡(luò)層的限制,這通常被稱為最大傳輸單元(MTU),在以太網(wǎng)環(huán)境中,標(biāo)準(zhǔn)的MTU大小通常為1500字節(jié),下面是一個(gè)Python示例,展示了如何通過(guò)UDP發(fā)送和接收超過(guò)64KB的數(shù)據(jù),需要的朋友可以參考下2024-08-08python非標(biāo)準(zhǔn)時(shí)間的轉(zhuǎn)換
本文主要介紹了python非標(biāo)準(zhǔn)時(shí)間的轉(zhuǎn)換,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07使用Pytorch+PyG實(shí)現(xiàn)MLP的詳細(xì)過(guò)程
圖神經(jīng)網(wǎng)絡(luò)是最近 AI 領(lǐng)域最熱門的方向之一,下面這篇文章主要給大家介紹了關(guān)于使用Pytorch+PyG實(shí)現(xiàn)MLP的詳細(xì)過(guò)程,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03Python如何讀取txt文件,獲取指定行中指定位置數(shù)據(jù)
這篇文章主要介紹了Python如何讀取txt文件,獲取指定行中指定位置數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03pycharm如何使用anaconda中的各種包(操作步驟)
這篇文章主要介紹了pycharm如何使用anaconda中的各種包,本文通過(guò)操作步驟給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07