Python utilities to convert openAIP data to SQLite
Python 2.7 (with the xml.etree and sqlite3 standard packages).
Tested with python 2.7.18 on windows 7 and python 2.7.15 on ubuntu18.04.
Open a terminal/command prompt and run
python run.py path/to/source airac [--verbose]
Where path/to/source is the relative path to the directory where the openAIP files are, and airac is the AIRAC number related to the files. Currently supported input formats:
- XML
- cup
- dat
The resulting database file will be located under sqlite/world.db.
Tables in the database:
- Airac (only has 1 row)
- id
PRIMARY KEY INTEGER - number
INTEGER
- id
- Countries
- id
PRIMARY KEY INTEGER - name
TEXT - code
TEXT
- id
- Airports
- id
PRIMARY KEY INTEGER - countryId
FOREIGN KEY INTEGER(referencesidof Countries entry) - name
TEXT - icao
TEXT - type
TEXT - country
TEXT - latitude
REAL - longitude
REAL - elevation
INTEGER - elevationUnit
TEXT
- id
- Airspaces
- id
PRIMARY KEY INTEGER - countryId
FOREIGN KEY INTEGER(referencesidof Countries entry) - name
TEXT - category
TEXT - ceiling
TEXT - ceilingUnit
TEXT - ceilingRef
TEXT(altimetry: height, altitude, flight level) - floor
TEXT - floorUnit
TEXT - floorRef
TEXT(altimetry: height, altitude, flight level) - lat
TEXT(comma-separated values of latitude perimeter points) - lng
TEXT(comma-separated values of longitude perimeter points)
- id
- Navaids
- id
PRIMARY KEY INTEGER - countryId
FOREIGN KEY INTEGER(referencesidof Countries entry) - name
TEXT - type
TEXT(ndb, vor, ...) - callsign
TEXT - latitude
REAL - longitude
REAL - elevation
INTEGER - elevationUnit
TEXT - frequency
TEXT - channel
TEXT - range
TEXT - rangeUnit
TEXT
- id
- Runways
- id
PRIMARY KEY INTEGER - airportId
FOREIGN KEY INTEGER(referencesidof Airports entry) - name
TEXT - surface
TEXT - length
INTEGER - lengthUnit
TEXT - width
INTEGER - widthUnit
TEXT
- id
- Frequencies
- id
PRIMARY KEY INTEGER - airportId
FOREIGN KEY INTEGER(referencesidof Airports entry) - callsign
TEXT - frequency
TEXT - category
TEXT(communication, navigation, ...) - type
TEXT(tower, ground, ...)
- id