refactored temp_log.py for versioned line formats, more extendable data return
This commit is contained in:
parent
1985c99fbd
commit
ea1ee9c386
34
temp_log.py
34
temp_log.py
|
@ -1,6 +1,30 @@
|
|||
#! /usr/bin/env python
|
||||
import serial, sys, time, io
|
||||
serialPort = '/dev/ttyACM0'
|
||||
defaultSerialPort = '/dev/ttyACM0'
|
||||
defaultVersion = 0
|
||||
|
||||
class ParseException(Exception):
|
||||
"""Parser Exceptions"""
|
||||
pass
|
||||
|
||||
|
||||
def parse_line(line, version = defaultVersion):
|
||||
"""Parses a line and returns an array index by name of the data available"""
|
||||
# @TODO This could be a class based versioning?
|
||||
data = {}
|
||||
if (version == 0):
|
||||
line = line.split(' ')
|
||||
data['temperature'] = float(line[-2])
|
||||
else:
|
||||
raise ParseException('Unimplemented line version', version)
|
||||
return data
|
||||
|
||||
|
||||
def main(args = sys.argv):
|
||||
# @TODO switch to parse args or similar
|
||||
# @TODO parse of temperature logger line version
|
||||
serialPort = defaultSerialPort
|
||||
lineVersion = defaultVersion
|
||||
try:
|
||||
serialPort = sys.argv[1]
|
||||
except Exception, e:
|
||||
|
@ -12,10 +36,12 @@ buffer = ''
|
|||
while True:
|
||||
try:
|
||||
buffer = ser.readline()
|
||||
buffer_split = buffer.split(' ')
|
||||
temp = float(buffer_split[-2])
|
||||
print unicode(time.time()) + ',' + unicode(temp)
|
||||
data = parse_line(buffer, lineVersion)
|
||||
print unicode(time.time()) + ',' + unicode(data['temperature'])
|
||||
sys.stdout.flush()
|
||||
except Exception, e:
|
||||
sys.stderr.write(str(e) + '\n')
|
||||
continue
|
||||
|
||||
if __name__ == '__main__':
|
||||
main(sys.argv)
|
||||
|
|
Loading…
Reference in New Issue