Skip to main content

A python parser for the FAA NASR

Project description

nasrparse

nasrparse is a parser for the National Airspace System Resources CSV files, released every 28 days by the FAA. It allows pilots, dispatchers, and others interested in flight data to quickly parse the files into Python dictionaries or a SQLite database for use in other programs. For example, the parsed data can then be used as a database for flight planning tools.

If you are interested in seeing the differences between each data cycle, have a look at NASRDiff.

Versions

Version Description Release Date
1.0.0 Initial public release. 2025-11-06

A changelog is available in the CHANGELOG.md with additional detail and guidance.

Installation

Install using pip:

pip install nasrparse

Usage

Usage is relatively straightforward. Setting the path to the files can be somewhat finnicky, as it will only accept relative paths. To keep things simple, place the NASR files in subdirectory of your project directory. Otherwise, if you want to go up several folders into a download folder, it might end up looking like ../../../../Downloads/28DaySubscription_Effective_[date]/CSV_Data/[date]_CSV.

Given the amount of data, parsing can take a moment. If dumping the data to a file, that can also add time. Dumping every airport to JSON can take around 10 seconds, and the result file is about 16MB.

Examples

Start by importing nasrparse, setting the path to the NASR CSV directory, and then parsing the data.

import nasrparse

# Initialize the parser:
from nasrparse import NASR

# Set the relative path to where you have the NASR CSV files:
n = NASR("./data/CSV_DATA/20_MAR_2025_CSV")

# Parse the data in the file:
n.parse()

Exporting Data

Database

Each object has its own to_db() method. This is useful when you would like the data to persist, or query it using standard database methods:

from nasrparse import NASR

n = NASR("./data/CSV_DATA/20_MAR_2025_CSV")
n.parse()
n.to_db("NASR.db")

NASR Objects

The individual NASR objects are exposed in the package and include the FAA descriptions in the code documentation. More detail can also be found in the individual [section] DATA LAYOUT.pdf (e.g. APT DATA LAYOUT.pdf) files included with the CSV files in the same directory.

Code Documentation

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nasrparse-1.0.0.tar.gz (119.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nasrparse-1.0.0-py3-none-any.whl (212.4 kB view details)

Uploaded Python 3

File details

Details for the file nasrparse-1.0.0.tar.gz.

File metadata

  • Download URL: nasrparse-1.0.0.tar.gz
  • Upload date:
  • Size: 119.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for nasrparse-1.0.0.tar.gz
Algorithm Hash digest
SHA256 cc33da4f76344c3d675c67da86b0d109d2ac25419f864e68fb811c24803143f4
MD5 2d51abb0da0e2acdcf04adee35d968bf
BLAKE2b-256 1476e58eba2ec179a755d33b9bdd3d2a8bb88b56a1bc3ff73a9f1b8a96510d43

See more details on using hashes here.

File details

Details for the file nasrparse-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: nasrparse-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 212.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for nasrparse-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d0ffa09aa94d4704bc555c34f244363e4ffa11a49fc56d234e93cb06d4994574
MD5 5722f3cfe070335b81a3196438b1e419
BLAKE2b-256 e27a7242ccc94cdd429ad4ed265c83ee84dcf33827fb60215b9b6345397708ad

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page