ADIF support in geolog

pull/3/head
Jeff Laughlin 2014-01-07 00:30:26 -05:00
rodzic 9dfdbd8912
commit facd0258cb
2 zmienionych plików z 42 dodań i 18 usunięć

Wyświetl plik

@ -149,13 +149,13 @@ class Reader(object):
int(rec['qso_date'][4:6]), int(rec['qso_date'][4:6]),
int(rec['qso_date'][6:8]), int(rec['qso_date'][6:8]),
int(rec['time_on'][:2]), int(rec['time_on'][:2]),
int(rec['time_on'][2:])) int(rec['time_on'][2:4]))
if 'qso_date' in rec and 'time_off' in rec: if 'qso_date' in rec and 'time_off' in rec:
rec['app_datetime_off'] = datetime(int(rec['qso_date'][:4]), rec['app_datetime_off'] = datetime(int(rec['qso_date'][:4]),
int(rec['qso_date'][4:6]), int(rec['qso_date'][4:6]),
int(rec['qso_date'][6:8]), int(rec['qso_date'][6:8]),
int(rec['time_off'][:2]), int(rec['time_off'][:2]),
int(rec['time_off'][2:])) int(rec['time_off'][2:4]))
yield rec yield rec
rec = OrderedDict() rec = OrderedDict()
else: else:

Wyświetl plik

@ -25,6 +25,7 @@ import traceback
import geojson as gj import geojson as gj
import adif
from ctydat import CtyDat, InvalidDxcc from ctydat import CtyDat, InvalidDxcc
import kml import kml
import qrz import qrz
@ -38,7 +39,7 @@ log = logging.getLogger('geolog')
# 4. Output GeoJSON # 4. Output GeoJSON
CABRILLO_FIELDS = ['header', 'freq', 'mode', 'date', 'time', CABRILLO_FIELDS = ['header', 'freq', 'mode', 'date', 'time',
'from_call', 'sent_qst', 'sent_ex', 'to_call', 'receved_qst', 'from_call', 'sent_rst', 'sent_ex', 'call', 'receved_rst',
'received_ex'] 'received_ex']
CACHEPATH = os.path.join(os.environ['HOME'], '.qrz_cache') CACHEPATH = os.path.join(os.environ['HOME'], '.qrz_cache')
@ -56,6 +57,9 @@ class Log(object):
for line in logfile: for line in logfile:
if line.startswith("QSO"): if line.startswith("QSO"):
qso = dict(zip(CABRILLO_FIELDS, line.split())) qso = dict(zip(CABRILLO_FIELDS, line.split()))
# Pygeojson just repr's numbers, which doesn't add .0 to
# floats, which makes them JSON ints, which QGIS won't allow to
# use for a graduated scale.
qso['time'] = float(qso['time'] + '.000000001') qso['time'] = float(qso['time'] + '.000000001')
qso['freq'] = float(qso['freq'] + '.000000001') qso['freq'] = float(qso['freq'] + '.000000001')
self.qsos.append(qso) self.qsos.append(qso)
@ -66,6 +70,19 @@ class Log(object):
log.info("Read %d records" % len(self.qsos)) log.info("Read %d records" % len(self.qsos))
return self return self
@staticmethod
def from_adif(logfile):
self = Log()
log = adif.Reader(logfile)
for qso in log:
try: del qso['app_datetime_on']
except KeyError: pass
try: del qso['app_datetime_off']
except KeyError: pass
self.qsos.append(qso)
self.callsign = qso['operator']
return self
def georeference(self, sess, ctydat): def georeference(self, sess, ctydat):
try: try:
rec = sess.qrz(self.callsign) rec = sess.qrz(self.callsign)
@ -86,27 +103,27 @@ class Log(object):
for qso in self.qsos: for qso in self.qsos:
qso['lat'], qso['lon'] = None, None qso['lat'], qso['lon'] = None, None
try: try:
rec = sess.qrz(qso['to_call']) rec = sess.qrz(qso['call'])
log.debug("qrz rec %s" % rec) log.debug("qrz rec %s" % rec)
if rec['call'] != qso['to_call']: if rec['call'] != qso['call']:
log.warning("qrz %s != %s" % (rec['call'], log.warning("qrz %s != %s" % (rec['call'],
qso['to_call'])) qso['call']))
if None in (rec['lat'], rec['lon']): if None in (rec['lat'], rec['lon']):
raise NullLoc() raise NullLoc()
qso['lat'], qso['lon'] = rec['lat'], rec['lon'] qso['lat'], qso['lon'] = rec['lat'], rec['lon']
except Exception, e: except Exception, e:
if isinstance(e, qrz.NotFound): if isinstance(e, qrz.NotFound):
log.warning("QRZ lookup failed for %s, not found" % qso['to_call']) log.warning("QRZ lookup failed for %s, not found" % qso['call'])
elif isinstance(e, NullLoc): elif isinstance(e, NullLoc):
log.warning("QRZ lookup failed for %s, no location data" % qso['to_call']) log.warning("QRZ lookup failed for %s, no location data" % qso['call'])
else: else:
log.warning("QRZ lookup failed for %s" % qso['to_call'], exc_info=True) log.warning("QRZ lookup failed for %s" % qso['call'], exc_info=True)
try: try:
dxcc = ctydat.getdxcc(qso['to_call']) dxcc = ctydat.getdxcc(qso['call'])
qso['lat'] = float(dxcc['lat']) qso['lat'] = float(dxcc['lat'])
qso['lon'] = float(dxcc['lon']) * -1 qso['lon'] = float(dxcc['lon']) * -1
except Exception: except Exception:
log.warning("cty.dat lookup failed for %s" % qso['to_call'], exc_info=True) log.warning("cty.dat lookup failed for %s" % qso['call'], exc_info=True)
raise raise
def geojson_dumps(self, *args, **kwargs): def geojson_dumps(self, *args, **kwargs):
@ -136,9 +153,9 @@ class Log(object):
callnode = dom.createPlacemark(self.callsign, self.lat, self.lon) callnode = dom.createPlacemark(self.callsign, self.lat, self.lon)
folder.appendChild(callnode) folder.appendChild(callnode)
for qso in self.qsos: for qso in self.qsos:
to_call, lat, lon = qso['to_call'], qso["lat"], qso["lon"] call, lat, lon = qso['call'], qso["lat"], qso["lon"]
callnode = dom.createPlacemark(to_call, lat, lon) callnode = dom.createPlacemark(call, lat, lon)
callnode2 = dom.createPlacemark(to_call, lat, lon) callnode2 = dom.createPlacemark(call, lat, lon)
theline = dom.createLineString( theline = dom.createLineString(
((lat, lon, 0), (self.lat, self.lon, 0)), ((lat, lon, 0), (self.lat, self.lon, 0)),
tessel=True) tessel=True)
@ -148,10 +165,17 @@ class Log(object):
folder.appendChild(callnode) folder.appendChild(callnode)
dom.writepretty(file) dom.writepretty(file)
def geolog(logfile, outfile, username, password, cachepath): def geolog(logfilepath, outfile, username, password, cachepath):
with open(logfile) as logfile: with open(logfilepath) as logfile:
log.info("Opened %r" % logfile) line = logfile.next()
qsolog = Log.from_cabrillo(logfile)
with open(logfilepath) as logfile:
if line.startswith('START-OF-LOG'):
log.info("Opened Cabrillo format log %r" % logfile)
qsolog = Log.from_cabrillo(logfile)
else:
log.info("Opened ADIF format log %r" % logfile)
qsolog = Log.from_adif(logfile)
with open('/home/jeff/Downloads/ctydat/cty.dat') as ctydat: with open('/home/jeff/Downloads/ctydat/cty.dat') as ctydat:
ctydat = CtyDat(ctydat) ctydat = CtyDat(ctydat)