Utilities for working with ICAO AIRAC cycles, including cycle calculations, validation, and conversions.
Project description
airac-tools
airac-tools is a Python package for working with ICAO AIRAC (Aeronautical Information Regulation And Control) cycles.
It provides a variety of utilities to determine cycle dates, validate cycle strings, perform conversions, iterate over cycles, and more.
Features
-
Cycle Information Functions
get_current_cycle(date: datetime = None) -> str: Get the current AIRAC cycle for a given date.get_next_cycle(date: datetime = None) -> str: Get the next AIRAC cycle after a given date.get_previous_cycle(date: datetime = None) -> str: Get the previous AIRAC cycle.get_cycle_start_date(cycle: str) -> datetime: Get the start date of a given AIRAC cycle.get_cycle_end_date(cycle: str) -> datetime: Get the end date of a given AIRAC cycle.
-
Date Conversion Functions
date_to_cycle(date: datetime) -> str: Convert any date to its corresponding AIRAC cycle.cycle_to_date(cycle: str) -> datetime: Convert an AIRAC cycle to its start date.
-
Validation Functions
is_valid_cycle(cycle: str) -> bool: Check if a given cycle string (like'2309') is valid.is_date_in_cycle(date: datetime, cycle: str) -> bool: Check if a date falls within a specific cycle.
-
Listing/Iteration Functions
list_cycles(year: int) -> list[str]: List all AIRAC cycles for a given year.cycles_between(start_cycle: str, end_cycle: str) -> list[str]: List all cycles between two cycles.dates_between(start_cycle: str, end_cycle: str) -> list[datetime]: List start dates for each cycle in a range.
-
Utility Functions
cycle_offset(cycle: str, offset: int) -> str: Returns the cycle offset by N cycles.format_cycle(cycle: str) -> str: Returns a human-readable cycle string.
Installation
Install from PyPI (when published):
pip install airac-tools
Or install locally (for development):
git clone https://github.com/jj-sm/airac-tools.git
cd airac-tools
pip install .
Usage
from airac_tools import cycle
# Get current AIRAC cycle
current_cycle = cycle.get_current_cycle()
print(cycle) # e.g., '2308'
# List all cycles in 2025
cycles_2025 = cycle.list_cycles(2025)
print(cycles_2025) # ['2501', ..., '2513']
# Convert date to cycle
from datetime import datetime, timezone
cycle_2 = cycle.date_to_cycle(datetime(2024, 8, 10, tzinfo=timezone.utc))
print(cycle) # e.g., '2408'
# Get cycle start/end dates
start = cycle.get_cycle_start_date('2408')
end = cycle.get_cycle_end_date('2408')
print(start, end)
# Check if date is within a cycle
cycle.is_date_in_cycle(datetime(2024, 8, 10, tzinfo=timezone.utc), '2408') # True
# Cycle offset
cycle.cycle_offset('2408', 2) # '2410'
# Format cycle
from airac_tools import utils
print(utils.format_cycle('2408')) # 'AIRAC 24/08'
Development
- Clone the repository and install in editable mode:
pip install -e .
- Run tests with:
pytest
- Code is formatted with PEP8.
- Contributions and issues are welcome!
License
MIT License.
Acknowledgements
AIRAC cycle rules are based on ICAO documentation and public sources.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file airac_tools-1.0.6.tar.gz.
File metadata
- Download URL: airac_tools-1.0.6.tar.gz
- Upload date:
- Size: 7.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
549a604bfbe82d530e83c1ada96dcfb097b3ab930f78753994eccc6c8b69ee22
|
|
| MD5 |
2cd5c884732496deef44c36463147425
|
|
| BLAKE2b-256 |
b4c93d0ba136990c6e045caef12225a9df9220e0de9ec37eab6777e607394de7
|
Provenance
The following attestation bundles were made for airac_tools-1.0.6.tar.gz:
Publisher:
publish.yaml on jj-sm/airac-cc
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
airac_tools-1.0.6.tar.gz -
Subject digest:
549a604bfbe82d530e83c1ada96dcfb097b3ab930f78753994eccc6c8b69ee22 - Sigstore transparency entry: 536395113
- Sigstore integration time:
-
Permalink:
jj-sm/airac-cc@81da357738b756b078dd065d31fc573521e7588c -
Branch / Tag:
refs/tags/v1.0.6 - Owner: https://github.com/jj-sm
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yaml@81da357738b756b078dd065d31fc573521e7588c -
Trigger Event:
push
-
Statement type:
File details
Details for the file airac_tools-1.0.6-py3-none-any.whl.
File metadata
- Download URL: airac_tools-1.0.6-py3-none-any.whl
- Upload date:
- Size: 6.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ce12b34805c040c16d3b46ba44929262f63adb614bcb2883e52244f30bf3939e
|
|
| MD5 |
c785a5184f532fd4ece423fb61c3755d
|
|
| BLAKE2b-256 |
cd6aab47c993655f90b6acceb39bcb6a32f2505c9fea5788da01fdbbee933c95
|
Provenance
The following attestation bundles were made for airac_tools-1.0.6-py3-none-any.whl:
Publisher:
publish.yaml on jj-sm/airac-cc
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
airac_tools-1.0.6-py3-none-any.whl -
Subject digest:
ce12b34805c040c16d3b46ba44929262f63adb614bcb2883e52244f30bf3939e - Sigstore transparency entry: 536395124
- Sigstore integration time:
-
Permalink:
jj-sm/airac-cc@81da357738b756b078dd065d31fc573521e7588c -
Branch / Tag:
refs/tags/v1.0.6 - Owner: https://github.com/jj-sm
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yaml@81da357738b756b078dd065d31fc573521e7588c -
Trigger Event:
push
-
Statement type: