Source code for geowriter
#!/usr/bin/env python
"""
.. module:: geowriter.py
:platform: Unix, Windows
:synopsis: Ulyxes - an open source project to drive total stations and
publish observation results.
GPL v2.0 license
Copyright (C) 2010- Zoltan Siki <siki.zoltan@epito.bme.hu>
.. moduleauthor:: Zoltan Siki <siki.zoltan@epito.bme.hu>
"""
import logging
from angle import Angle
from filewriter import FileWriter
[docs]class GeoWriter(FileWriter):
""" Class to write observations to csv file
:param name: name of writer (str), default None
:param angle: angle unit to use (str), default GON
:param dist: distance and coordinate format (str), default .3f
:param dt: date/time format (str), default ansi
:param filt: list of keys to output (list), default None (use all)
:param fname: name of text file to write to (str)
:param mode: mode of file open (a or w) (str)
"""
# ulyxes to GeoEasy code translator
codes = {'station': 2, 'ih': 3, 'id': 5, 'th': 6,
'hz': 7, 'v': 8, 'distance': 9, 'hd': 11, 'faces': 112, 'pc': 20,
'datetime': 51, 'east': 38, 'north': 37, 'elev': 39, 'code': 4,
'lengthincline': 200, 'crossincline': 201}
def __init__(self, name='None', angle='DMS', dist='.3f',
dt='%Y-%m-%d %H:%M:%S', filt=None, fname=None, mode='a'):
""" Constructor
"""
super().__init__(name, angle, dist, dt, filt, fname, mode)
def __del__(self):
""" Destructor
"""
try:
self.fp.close()
except Exception:
pass
[docs] def WriteData(self, data):
""" Write observation data to csv file
:param data: dictionary with observation data
:returns: non zero if error
"""
if data is None or self.DropData(data):
logging.warning(" empty or inappropiate data not written")
return -2
# add datetime and/or id
data = self.ExtendData(data)
# remove point id or station if both are given
if 'station' in data and 'id' in data:
if 'hz' in data or 'v' in data or 'distance' in data:
del data['station']
else:
del data['id']
line = ''
for key, val in data.items():
if key in self.codes and (self.filt is None or key in self.filt):
line = line + '{' + str(self.codes[key]) + ' ' + \
self.StrVal(val) + '} '
try:
self.fp.write(line + "\n")
self.fp.flush()
except Exception:
logging.error(" file write failed")
return -1
return 0
if __name__ == "__main__":
myfile = GeoWriter()
data = {'station': 111, 'ih': 1.234}
myfile.WriteData(data)
data = {'hz': Angle(0.12345), 'v': Angle(100.2365, 'GON'),
'distance': 123.6581, 'lengthincline': Angle(0.0008, 'GON'),
'crossincline': Angle(0.0011, 'GON')}
myfile.WriteData(data)