2016-10-25 8 views
1

.csv로 구문 분석하고 형식을 변경하려고하는 텍스트 파일이 있습니다. 텍스트 파일은 2Hz마다 반복되는 상태 메시지로 만들어져 다양한 값을 출력합니다. 모든 메시지에는 '-----------'헤더, '/ n'개행 문자 및 ''바닥 글이 있습니다.반복되는 메시지를 구문 분석하기위한 최고의 Pythonic 접근 방식

이 작업을 수행하는 가장 좋은 방법은 한 번에 하나의 '메시지'만 읽고 내 출력 파일을 업데이트 할 수 있다고 생각합니다. 저는 파이썬 3.5 (파이썬 3.5 사용)에 익숙하지 않습니다. 여기 등

----------- 
2016-10-10T14:03:38,158000277+0000 
14:03:38 up 1 min, 2 users, load average: 0.58, 0.13, 0.04 
acpitz-virtual-0 
Adapter: Virtual device 
temp1:  +27.8°C (crit = +110.0°C) 
temp2:  +29.8°C (crit = +110.0°C) 

coretemp-isa-0000 
Adapter: ISA adapter 
Physical id 0: +44.0°C (high = +105.0°C, crit = +105.0°C) 
Core 0:   +44.0°C (high = +105.0°C, crit = +105.0°C) 
Core 1:   +44.0°C (high = +105.0°C, crit = +105.0°C) 

nct6776-isa-0a00 
Adapter: ISA adapter 
Vcore:     +1.79 V (min = +0.00 V, max = +1.74 V) ALARM 
in1:     +1.35 V (min = +0.00 V, max = +0.00 V) ALARM 
AVCC:     +3.33 V (min = +2.98 V, max = +3.63 V) 
+3.3V:     +3.33 V (min = +2.98 V, max = +3.63 V) 
in4:     +1.00 V (min = +0.00 V, max = +0.00 V) ALARM 
in5:     +0.00 V (min = +0.00 V, max = +0.00 V) 
in6:     +0.27 V (min = +0.00 V, max = +0.00 V) ALARM 
3VSB:     +3.30 V (min = +2.98 V, max = +3.63 V) 
Vbat:     +3.20 V (min = +2.70 V, max = +3.63 V) 
fan1:      0 RPM (min = 0 RPM) 
fan2:      0 RPM (min = 0 RPM) 
SYSTIN:     +68.0°C (high = +0.0°C, hyst = +0.0°C) ALARM sensor = thermistor 
CPUTIN:     +22.5°C (high = +80.0°C, hyst = +75.0°C) sensor = CPU diode 
AUXTIN:     +28.5°C (high = +80.0°C, hyst = +75.0°C) sensor = CPU diode 
PCH_CHIP_CPU_MAX_TEMP: +26.0°C (high = +80.0°C, hyst = +75.0°C) 
PECI Agent 0:   +44.0°C (high = +80.0°C, hyst = +75.0°C) 
           (crit = +105.0°C) 
PCH_CHIP_TEMP:   +0.0°C 
PCH_CPU_TEMP:   +0.0°C 
intrusion0:   OK 
intrusion1:   OK 

내가 각 메시지, 온도, 전압의 날짜/시간 같은 것들을 꺼내 할

을 내 슈퍼 명사에 붙여서의 뜻을 나타냄을이다 :

는 입력 데이터는 다음과 같습니다 파이썬 방법 (들여 쓰기가 복사 및 붙여 넣기 동안 엉망이있어주의 ... 그것은 실제 코드에서 올바른) :

with open('102_sensors.log', 'r') as readFile, open('output.txt','w') as writeFile: 
for line in readFile: 
    if line.startswith('2016'):    
     writeFile.write(line[:10] + ',' + line[11:-1] + ',') #date and time 
    if 'load average' in line: 
     writeFile.write(line[13:15] + ',' + line[-17:-1] + ',') #up-time and load avgs 
    if 'temp1' in line: 
     writeFile.write(line[15:19] + ',')    
    if 'temp2' in line: 
     writeFile.write(line[15:19] + ',')    
    if 'Physical id 0' in line: 
     writeFile.write(line[17:21] + ',') 
    if 'Core 0' in line: 
     writeFile.write(line[17:21] + ',') 
    if 'Core 1' in line: 
     writeFile.write(line[17:21] + ',') 
    if 'Vcore' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'in1' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'AVCC' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'threeV' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'in4' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'in5' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'in6' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'threeVSB' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'Vbat' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'SYSTIN' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'CPUTIN' in line: 
     writeFile.write(line[25:29] + ',') 
    if 'AUXTIN' in line: 
     writeFile.write(line[25:29] + ',') 
    if '-----------' in line: 
     writeFile.write('\n') 
     continue 
writeFile.close() 

답변

0

사용 re 모듈은 입력을 구문 분석 할 수 있습니다. csv 모듈을 사용하여 출력을 작성하십시오. reference manual의 예와 예는 다음과 같습니다.

import csv 
with open('eggs.csv', 'w', newline='') as csvfile: 
    spamwriter = csv.writer(csvfile, delimiter=' ', 
          quotechar='|', quoting=csv.QUOTE_MINIMAL) 
    spamwriter.writerow(['Spam'] * 5 + ['Baked Beans']) 
    spamwriter.writerow(['Spam', 'Lovely Spam', 'Wonderful Spam']) 
+0

내가 작성한 것보다 re 모듈의 성능이 어떻습니까? 그것은 더 빠릅니까? 읽기 쉽니? – drone007