Heim > Backend-Entwicklung > Python-Tutorial > Python analysiert Protokolldateien im XML-Format

Python analysiert Protokolldateien im XML-Format

高洛峰
Freigeben: 2017-02-28 09:19:52
Original
1353 Leute haben es durchsucht

Guten Tag allerseits. Da ich während des chinesischen Neujahrs nicht in meinen Normalzustand zurückgekehrt bin, habe ich schon lange keine Welle des Wissens mehr geteilt. Heute werde ich weiterhin eine kleine Welle mit euch teilen Skripte zum Parsen von Protokollen in Python.

Schauen wir uns zunächst einmal an, wie das Protokoll aussieht.

Python analysiert Protokolldateien im XML-Format

Sie sind alle im XML-Format, wenn Sie sie nur ansehen. ? Es ist in Ordnung, lass es uns zuerst analysieren.

1. Der Anfang jedes Absatzes ist catalina-exec, daher werden wir ihn nach dem Teilen in Absätze unterteilen.

2. Dann teilen wir es in die Segmente auf, die Sie segmentieren möchten, und finden die Schlüsselwörter, die Sie segmentieren möchten. Da es sich um XML handelt, handelt es sich bei der nächsten Arbeit um einen einzigen Header .

3. Es ist jedoch möglich, dass einige von ihnen nicht die gewünschten Schlüsselwörter haben. Wenn es kein solches Feld gibt, werde ich dieses Feld auf leer setzen .

Wenn die Ideen klar sind, wird der Code natürlich einfacher.

Als nächstes schauen wir uns den Code an

#coding:utf-8 
import re 
#文本所在TXT文件 
file = 'iag_interface.log' 
#分割一段 
xml1='catalina-exec' 
xml2='catalina-exec' 
#关键字reqtimestamp 
time1 = &#39;<timestamp>&#39; 
time2 = &#39;</timestamp>&#39; 
#关键字functionid 
functionid1 = &#39;<functionid>&#39; 
functionid2 = &#39;</functionid>&#39; 
#关键字transid 
transid1=&#39;<transid>&#39; 
transid2=&#39;</transid>&#39; 
#关键字siappid 
siappid1=&#39;<siappid>&#39; 
siappid2=&#39;</siappid>&#39; 
#关键字userid 
userid1=&#39;<userid>&#39; 
userid2=&#39;</userid>&#39; 
#关键字mobnum 
mobnum1=&#39;<mobnum>&#39; 
mobnum2=&#39;</mobnum>&#39; 
f = open(file,&#39;r&#39;,encoding= &#39;utf-8&#39;) 
#f = open(file,&#39;r&#39;) 
#for (num,value) in enumerate(f): 
 #print("line number",num,"is:",value) 
buff = f.read() 
#清除换行符,请取消下一行注释 
#buff = buff.replace(&#39;\n&#39;,&#39;&#39;) 
pat = re.compile(time1+&#39;(.*?)&#39;+time2,re.S) 
pat1 = re.compile(functionid1+&#39;(.*?)&#39;+functionid2,re.S) 
pat2 = re.compile(transid1+&#39;(.*?)&#39;+transid2,re.S) 
pat3 = re.compile(siappid1+&#39;(.*?)&#39;+siappid2,re.S) 
pat4 = re.compile(userid1+&#39;(.*?)&#39;+userid2,re.S) 
pat5 = re.compile(mobnum1+&#39;(.*?)&#39;+mobnum2,re.S) 
pat6=re.compile(xml1+&#39;(.*?)&#39;+xml2,re.S) 
result6 = pat6.findall(buff) 
print(len(result6)) 
x = open("logfx.txt", &#39;w&#39;) 
x.write("===========================开始数据================================="+"\n") 
x.write("time"+"\t"+"functionid"+"\t"+"transid"+"\t"+"siappid"+"\t"+"userid"+"\t"+"mobnum"+"\n") 
for i in range(0,len(result6)): 
 result = pat.findall(result6[i]) 
 result1 = pat1.findall(result6[i]) 
 result2 = pat2.findall(result6[i]) 
 result3 = pat3.findall(result6[i]) 
 result4 = pat4.findall(result6[i]) 
 result5 = pat5.findall(result6[i]) 
 if len(result)==0: 
  result.append("空") 
 if len(result1)==0: 
  result1.append("空") 
 if len(result2)==0: 
  result2.append("空") 
 if len(result3)==0: 
  result3.append("空") 
 if len(result4)==0: 
  result4.append("空") 
 if len(result5)==0: 
  result5.append("空") 
 #print(result[0],"=",result1[0],"=",result2[0],"=",result3[0],"=",result4[0],"=",result5[0]) 
 x.write("timestamp:"+result[0]+"\t"+result1[0]+"\t"+result2[0]+"\t"+result3[0]+"\t"+result4[0]+"\t"+"mobnum:"+result5[0]+"\n") 
x.write("===========================结束数据================================="+"\n")  
print("执行完毕!生成文件logfx.txt") 
x.close()
Nach dem Login kopieren

Führen Sie den Code aus

Python analysiert Protokolldateien im XML-Format

Python hat Protokolldateien basierend auf dem XML-Format analysiert und alle Daten erfolgreich ausgeführt. Überprüfen Sie anschließend die Datei

Python analysiert Protokolldateien im XML-Format

Okay.

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass er zum Lernen aller beiträgt. Ich hoffe auch, dass jeder die PHP-Chinesisch-Website unterstützt.

Weitere Artikel zum Parsen von Protokolldateien im XML-Format in Python finden Sie auf der chinesischen PHP-Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage