ogn-python/ogn/model/beacon.py

64 wiersze
2.0 KiB
Python
Czysty Zwykły widok Historia

2015-10-24 21:13:21 +00:00
import re
from sqlalchemy import Column, String, Integer, Float, DateTime
from sqlalchemy.ext.declarative import AbstractConcreteBase
2015-10-25 13:23:25 +00:00
from ogn.aprs_utils import createTimestamp, dmsToDeg, kts2kmh, feet2m
2015-11-15 18:21:19 +00:00
from ogn.exceptions import AprsParseError
2015-10-30 20:19:03 +00:00
from .base import Base
2015-10-24 21:13:21 +00:00
# "original" pattern from OGN: "(.+?)>APRS,.+,(.+?):/(\\d{6})+h(\\d{4}\\.\\d{2})(N|S).(\\d{5}\\.\\d{2})(E|W).((\\d{3})/(\\d{3}))?/A=(\\d{6}).*?"
PATTERN_APRS = r"^(.+?)>APRS,.+,(.+?):/(\d{6})+h(\d{4}\.\d{2})(N|S)(.)(\d{5}\.\d{2})(E|W)(.)((\d{3})/(\d{3}))?/A=(\d{6})\s(.*)$"
2015-11-15 18:21:19 +00:00
re_pattern_aprs = re.compile(PATTERN_APRS)
2015-10-24 21:13:21 +00:00
class Beacon(AbstractConcreteBase, Base):
id = Column(Integer, primary_key=True)
# APRS data
name = Column(String)
receiver_name = Column(String(9))
timestamp = Column(DateTime, index=True)
latitude = Column(Float)
symboltable = None
longitude = Column(Float)
symbolcode = None
track = Column(Integer)
2015-10-25 13:23:25 +00:00
ground_speed = Column(Float)
2015-10-24 21:13:21 +00:00
altitude = Column(Integer)
comment = None
2015-12-10 06:43:18 +00:00
def parse(self, text):
2015-11-15 18:21:19 +00:00
result = re_pattern_aprs.match(text)
2015-10-24 21:13:21 +00:00
if result is None:
2015-11-19 22:17:12 +00:00
raise AprsParseError(text)
2015-10-24 21:13:21 +00:00
self.name = result.group(1)
self.receiver_name = result.group(2)
2015-12-10 06:43:18 +00:00
self.timestamp = createTimestamp(result.group(3))
2015-10-24 21:13:21 +00:00
self.latitude = dmsToDeg(float(result.group(4)) / 100)
if result.group(5) == "S":
self.latitude = -self.latitude
self.symboltable = result.group(6)
self.longitude = dmsToDeg(float(result.group(7)) / 100)
if result.group(8) == "W":
self.longitude = -self.longitude
self.symbolcode = result.group(9)
if result.group(10) is not None:
2015-10-25 13:23:25 +00:00
self.track = int(result.group(11))
2015-11-15 18:21:19 +00:00
self.ground_speed = int(result.group(12)) * kts2kmh
2015-10-24 21:13:21 +00:00
else:
self.track = 0
2015-10-25 13:23:25 +00:00
self.ground_speed = 0
2015-10-24 21:13:21 +00:00
2015-11-15 18:21:19 +00:00
self.altitude = int(result.group(13)) * feet2m
2015-10-24 21:13:21 +00:00
self.comment = result.group(14)