Skip to main content

A Python client for the Flightradar24 API with CLI support

Project description

Pyfr24

Documentation Status

A Python client for the Flightradar24 API that provides an interface to fetch, plot and analyze flight data. The package includes both a Python API and a command-line interface for accessing flight data.

Full documentation: https://pyfr24.readthedocs.io/

Installation

# Install from PyPI
pip install pyfr24

# Or from source
git clone https://github.com/stiles/pyfr24.git
cd pyfr24
pip install -e .

Basic usage

Python API

from pyfr24 import FR24API

# Initialize the client
api = FR24API("your_api_token")

# Get flight tracks for a specific flight ID
tracks = api.get_flight_tracks("39bebe6e")

# Export flight data
output_dir = api.export_flight_data(
    "39bebe6e",
    background='osm',        # OpenStreetMap background
    orientation='horizontal'  # 16:9 aspect ratio
)

Full Python docs: https://pyfr24.readthedocs.io/en/latest/usage/api/

Command-line interface

# Export flight data
pyfr24 export-flight --flight-id 39a84c3c --output-dir data/flight_39a84c3c

# Get live flights for an aircraft registration
pyfr24 live-flights --registration N12345

# Get flight positions within a bounding box (Los Angeles area)
pyfr24 flight-positions --bounds "33.5,-118.8,34.5,-117.5"

# Smart export
pyfr24 smart-export --flight UA2151 --date 2025-04-22

Full CLI reference: https://pyfr24.readthedocs.io/en/latest/usage/cli/

API token

Your Flightradar24 API token can be provided:

  1. Via environment variable:

    export FLIGHTRADAR_API_KEY="your_api_token"
    
  2. As a command-line argument:

    pyfr24 --token "your_api_token" flight-summary --flight BA123
    
  3. Through an interactive prompt when no token is provided

Smart export (new!)

Easily export all data for a flight when you know the flight number and date, but not the internal flight ID. This command is ideal for quickly investigating incidents or flights reported in the news, as it will look up all matching flights for the given number and date, prompt you to select if there are multiple, and export all relevant data and visualizations in one step.

Export all data for a flight by flight number and date, with interactive selection if there are multiple matches:

pyfr24 smart-export --flight UA2151 --date 2025-04-22
  • If multiple flights are found, you'll be prompted to select the correct one.
  • The output directory is named automatically (e.g., data/UA2151_2025-04-22_KEWR-KDEN_3a01b036).
  • A toplines.json file is created with a summary of the exported flight.

Example output:

Multiple flights found for UA2151 on 2025-04-22:
[0] 3a00e15e | KPWM  KEWR | 2025-04-22T10:34–2025-04-22T11:46 | N37554 | B39M
[1] 3a01b036 | KEWR  KDEN | 2025-04-22T14:48–2025-04-22T18:53 | N28457 | B739
Select a flight to export [0-1]: 1
...
Export complete!

Features

  • Flight data retrieval (live flights, historical tracks and detailed info)
  • Data export in multiple formats (CSV, GeoJSON and KML)
  • Customizable map visualizations with multiple background options
  • Speed and altitude profile charts
  • Robust error handling and logging
  • Comprehensive testing
  • Interactive CLI export by flight number and date (smart-export command)
  • Topline summary output (toplines.json)

Contributing

Contributions are welcome. Please:

  1. Fork the repository
  2. Create a feature branch
  3. Add tests for new functionality
  4. Ensure all tests pass with python run_tests.py
  5. Submit a pull request

License

This project is licensed under the MIT License.

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

pyfr24-0.1.7.tar.gz (24.0 kB view details)

Uploaded Source

Built Distribution

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

pyfr24-0.1.7-py3-none-any.whl (25.1 kB view details)

Uploaded Python 3

File details

Details for the file pyfr24-0.1.7.tar.gz.

File metadata

  • Download URL: pyfr24-0.1.7.tar.gz
  • Upload date:
  • Size: 24.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for pyfr24-0.1.7.tar.gz
Algorithm Hash digest
SHA256 b13fdbbfcffb559e278fb1e54d15d4e329c1c792b41e2d9474bde25e4dc1be48
MD5 ad4b236f9119522fef4858ede91e9e1b
BLAKE2b-256 3e0e4ab62ecc87eff6443978805bf7ccb425371c7963903cfed63730689c2fa3

See more details on using hashes here.

File details

Details for the file pyfr24-0.1.7-py3-none-any.whl.

File metadata

  • Download URL: pyfr24-0.1.7-py3-none-any.whl
  • Upload date:
  • Size: 25.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for pyfr24-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 2d538a4aa1e5bf9ffd09ed87d8c50556cf2926841ccc10daa0711b681ce17251
MD5 ff546b3a26176417dd085ce3eab48f46
BLAKE2b-256 c1498c48eb366614b526ab8e3f63b70eb59ae08d7e3d26aec71e75fd160bffe4

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