Auto download airports.dat

This commit is contained in:
Jack Sweeney 2020-11-10 01:19:33 +00:00 committed by GitHub
parent 7cb7c538d6
commit 1953a87a08
3 changed files with 52 additions and 30 deletions

View File

@ -9,7 +9,9 @@ if platform.system() == "Windows":
init(convert=True)
from planeClass import Plane
from datetime import datetime
from defAirport import DownloadAirports
import pytz
DownloadAirports()
main_config = configparser.ConfigParser()
main_config.read('./configs/mainconf.ini')
import os
@ -83,4 +85,3 @@ while True:
time.sleep(1)
sys.stdout.write(Back.RED + ('\x1b[1K\r' +"Slept for " +str(sleep_sec)) + Style.RESET_ALL)
print()

View File

@ -1,6 +1,27 @@
#https://www.geeksforgeeks.org/python-calculate-distance-between-two-places-using-geopy/
#https://openflights.org/data.html
def getAirport(latitude, longitude):
def DownloadAirports():
import os
if not os.path.isfile('airports.dat'):
print("No airports.dat file, downloading now")
try:
import requests
url = 'https://raw.githubusercontent.com/jpatokal/openflights/master/data/airports.dat'
airports = requests.get(url)
open('airports.dat', 'wb').write(airports.content)
except:
raise("Error getting airports.dat or storing")
else:
#Writes current date to airports.dat to show when it was aqquired
import datetime
date = datetime.datetime.now()
with open('airports.dat', 'a') as airports:
airports.write("#" + str(date))
print("Successfully got airports.dat")
elif os.path.isfile('airports.dat'):
print("Already Have airports.dat, continuing")
def getClosestAirport(latitude, longitude):
import json
import csv
from geopy.distance import geodesic
@ -9,7 +30,7 @@ def getAirport(latitude, longitude):
airports = []
first_run = True
with open('airports.dat', encoding='utf-8') as csvf:
reader = csv.DictReader( csvf, header)
reader = csv.DictReader(filter(lambda row: row[0]!='#', csvf), header)
#for row in reader:
# airports.append(row)
for row in reader:

View File

@ -47,7 +47,7 @@ class Plane:
import platform
from datetime import datetime
from tabulate import tabulate
from defAirport import getAirport
from defAirport import getClosestAirport
if self.config.get('MAP', 'OPTION') == "GOOGLESTATICMAP":
from defMap import getMap
elif self.config.get('MAP', 'OPTION') == "ADSBX":
@ -304,7 +304,7 @@ class Plane:
raise Exception("Map option not set correctly in this planes conf")
#Discord
if self.config.getboolean('DISCORD', 'ENABLE'):
nearest = getAirport(self.latitude, self.longitude)
nearest = getClosestAirport(self.latitude, self.longitude)
self.dis_message = (self.dis_title + " " + self.tookoff_message + nearest['icao'] + ", " + nearest["name"]).strip()
sendDis(self.dis_message, self.map_file_name, self.config)
#PushBullet
@ -346,7 +346,7 @@ class Plane:
raise Exception("Map option not set correctly in this planes conf")
#Discord
if self.config.getboolean('DISCORD', 'ENABLE'):
nearest = getAirport(self.last_latitude, self.last_longitude)
nearest = getClosestAirport(self.last_latitude, self.last_longitude)
self.dis_message = (self.dis_title + " " +self.landed_message + nearest['icao'] + ", " + nearest["name"]).strip()
sendDis(self.dis_message, self.map_file_name, self.config)
#PushBullet