Skip to main content

ADIF file utilities

Project description

adiftools Logo

adiftools: adif file utility tools for all amateur radio stations

Item Status
Testing PyPI - Python Version GitHub issue custom search in repo
Package GitHub Release GitHub Release Date
Meta License: MIT
Stats PyPI - Downloads GitHub Downloads (all assets, all releases) GitHub commit activity

|

What is it?

adiftools is a Python package that provides utilities for ADIF data which is used for the QSO logging file format.

This tool allows you to easily load all QSO data from an ADIF file into a pandas DataFrame. Additionally, it provides functions for graphing the loaded data, as well as utility functions for Grid Locator-related latitude and longitude conversion and distance measurement.

Main Features

  • ADIF file parser: Read ADIF file and convert to pandas DataFrame

    • Call signature:
      ADIFParser.read_adi(file_path, enable_timestamp=False)
      
    • Parameters:
      • file_path: str or path-like or binary file-like
        • A path or a Python file-like object representing the ADIF file to read.
    • Returns:
      • pd.DataFrame
        • The created pandas DataFrame instance includes QSO data from the ADIF file.
    • Other Parameters:
      • enable_timestamp: bool, default: False
        • If True, adds a row named ['timestamp'] to the DataFrame, generated from the ADIF file. The ['timestamp'] row is of type datetime64[ns] and is based on the 'QSO_DATE' and 'TIME_ON' fields.
  • Save ADIF data as adi file

    • Saves the loaded ADIF data as an adi file conforming to the ADIF standard. adiftools adds a new header to the beginning of the adi file.
    • Fields with no data are filled with nan.
    • The header will contain information on the following two fields, CREATED_TIMESTAMP, and PROGRAMID.
    • Call signature:
      ADIFParser.to_adi(file_path)
      
    • Parameter:
      • file_path: str or path-like or binary file-like
        • A path, or a Python file-like object of adi file to save
      • Returns:
        • None
  • Save ADIF data as pickle file: Save the DataFrame with the ADIF loaded to a pickle file.

    • Loading an ADIF file into a DataFrame can be quite time consuming.
    • It is especially long if there are many QSOsin the ADIF file, and it is very cumbersome to read the data every time.
    • It is recommended to serialize the ADIF data once loaded and save it in a pickle format, which is expected to be 50 times faster than loading a raw ADIF file.
    • Call signature:
      ADIFParser.to_pickle(file_path)
      
    • Parameter:
      • file_path: str or path-like or binary file-like
        • A path, or a Python file-like object of pickle file to save
      • Returns:
        • None
  • Load Pickle data

    • Provides a way to read ADIF data once it has been loaded by ADIFParser and saved in a pickle file.
    • The read_pickle method does not check whether the QSO data is saved in the read pickle file.
    • Call signature:
      ADIFParser.read_pickle(file_path)
      
    • Parameter:
      • file_path: str or path-like or binary file-like
        • A path, or a Python file-like object of pickle file to read
      • Returns:
        • pd.DataFrame
          • The created pandas.DataFrame instance includes QSO data from ADIF file
  • Save ADIF data as excel file: Save the DataFrame with the ADIF loaded to an excel file.

    • Call signature:
      ADIFParser.to_excel(file_path)
      
    • Parameter:
      • file_path: str or path-like or binary file-like
        • A path, or a Python file-like object of excel file to save
      • Returns:
        • None
  • Generate Callsign file

    • Outputs call sign data without duplicates from data read from an ADIF file as a text file. The text file will contain one callsign per line.
    • If the ADIF file has not been read, i.e., read_adi() has not been performed, it returns the error AdifParserError.
    • Call signature:
      ADIFParser.call_to_txt(file_path)
      
    • Parameter:
      • file_path: str or path-like or binary file-like
        • A path of output txt file
    • Returns:
      • None
  • ADIF data monthly plot: Generate monthly QSO plot

    • Call signature:

      ADIFParser.plot_monthly(file_path)
      

      Generates a bar plot of monthly QSOs and saves a PNG or JPG file.

    • Parameters:

      • file_path: str or path-like or binary file-like
        • A path or a Python file-like object of the plot's PNG or JPG file.
    • Returns:

      • None
  • Monthly Band QSO Stacked Bar Plot: Generate stacked bar plot of monthly QSO counts by band

    • Call signature:
      ADIFParser.plot_monthly_band(file_path)
      
      Generates a stacked bar plot of monthly QSO counts by band and saves a PNG or JPG file. Each band is assigned a unique color for clarity. The color table for each BAND is defined inside the function, and if a BAND is not listed, a unique color is automatically assigned from a colormap to avoid duplication.

    The color codes are inspired by the color scheme used on the website PSKReporter. We would like to acknowledge and thank PSKReporter for their excellent and informative color palette.

    If you wish to customize the color assignment, please edit the color table in the source code of the function monthly_band_qso in adifgraph.py.

    • Parameters:
      • file_path: str or path-like or binary file-like
        • A path or a Python file-like object of the plot's PNG or JPG file.
    • Returns:
      • None
    BAND Color Code
    2M #FF1493
    4M #CC0044
    5M #E0E0E0
    6M #FF0000
    8M #7F00F1
    10M #FF69B4
    11M #00FF00
    12M #B22222
    15M #CCA166
    17M #F2F261
    20M #F2C40C
    30M #62D962
    40M #5959FF
    80M #E550E5
    160M #7CFC00

    Any BAND not listed above will be assigned a unique color from the colormap automatically.

  • Band percentage plot: Generate pie plot to show QSO-Band percentage

    • Call signature:

      ADIFParser.plot_band_percentage(file_path)
      

      Generates a pie plot of QSO-band counts and saves a PNG or JPG file.

    • Parameters:

      • file_path: str or path-like or binary file-like
        • A path or a Python file-like object of the plot's PNG or JPG file.
    • Returns:

      • None
  • Grid Locator utilities

    • Calculate geographic coordination from GL

      • Call signature:
        adiftools.gl2latlon(gridlocator)
        
      • Parameter:
        • gridlocator: str of grid locator. 4 or 6 digits, regardless of upper or lower case.
      • Returns:
        • (latitude, longitude): tuple of latitude and longitude in decimal degree unit (DD/DEG format).
    • Calculate grid locators from latitude and longitude

      • Call signature
        adiftools.latlon2gl(latitude, longitude, fourdigit=False)
        
      • Parameters:
        • latitude in decimal degree unit
        • longitude in decimal degree unit
        • fourdigit if True, returns 4-digit grid square
    • Reference

    • Calculate distance from two places' latitude and longitude

      • Call signature
        adiftools.get_dist(lat1, lon1, lat2, lon2)
        
      • Parameters:
        • lat1 – latitude of the first point in degrees
        • lon1 – longitude of the first point in degrees
        • lat2 – latitude of the second point in degrees
        • lon2 – longitude of the second point in degrees
      • Returns:
        • the distance from the first point to the second in meters
      • Reference
  • Call Sign Utility

    • Check JA call sign
      • Call signature
        adiftools.is_ja(call_sign)
        
      • Parameter:
        • call_sign call sign in string
      • Returns:
        • True: JA call, False: other
    • Check Area
      • Call signature
        adiftools.get_area(call_sign)
        
      • Parameter:
        • call_sign call sign in string
      • Returns:
        • number: area number, None: n/a

Note: adiftools is not support ADX file format at this moment.

Install

adiftools has been tested against Python 3.11, 3.12, and 3.13. It may work with Python 3 prior to 3.10, but we recommend using 3.11 or higher versions.

It is recommended to create a virtual environment and install adiftools inside the virtual environment.

Binary installers for the latest released version is available via PyPI: adiftools · PyPI.

pip install adiftools

If you are using an older version of adiftools, please use the following command to update it to the latest version.

pip install -U adiftools

Unfortunately, if you no longer need adiftools, you can uninstall it with the following command.

pip uninstall adiftools

Testing version

We have decided not to update adiftools on the TestPyPI site anymore.

For detail, please see TestPyPI website: adiftools · TestPyPI

pip install -i https://test.pypi.org/simple/ adiftools==0.0.5

Getting Started

The first step in utilizing adiftools is to load an ADIF file; files that follow the ADIF standard can be loaded. After loading an adif file, you can perform graphing and other operations. Please refer to this page for ADIF standard. The Independent ADIF Site

Example:

import adiftools.adiftools as adiftools

adi = adiftools.ADIFParser()

df_adi = adi.read_adi('sample.adi') # Use your own adi file
print(df)

Dependencies

adiftools requires the following Python packages (recommended versions):

You can install all dependencies with:

pip install adiftools

FAQ / Troubleshooting

  • If you encounter an error related to subprocess or wheel, please try installing wheel with pip install wheel.
  • For other common issues, please refer to the adiftools issue tracker or open a new issue for support.

Licence

MIT

日本語での情報提供

Information in Japanese is available on the following blogs. Information updates are prioritised on Github, and information updates on the following blogs are slightly delayed.

TU de JS2IIU 73

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

adiftools-0.1.10.tar.gz (18.7 kB view details)

Uploaded Source

Built Distribution

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

adiftools-0.1.10-py3-none-any.whl (13.7 kB view details)

Uploaded Python 3

File details

Details for the file adiftools-0.1.10.tar.gz.

File metadata

  • Download URL: adiftools-0.1.10.tar.gz
  • Upload date:
  • Size: 18.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for adiftools-0.1.10.tar.gz
Algorithm Hash digest
SHA256 e783ecf5e1ae52349ff7e9e5dc3d0c00820b05479084f6790c3637314f0b603b
MD5 f061a50d1c2c357ee96dbef86380aad4
BLAKE2b-256 6ed7243eb6a52637c0c29bd4f880d2c79603347c49864aed0762be2a0b24df1e

See more details on using hashes here.

Provenance

The following attestation bundles were made for adiftools-0.1.10.tar.gz:

Publisher: publish-to-pypi.yml on JS2IIU-MH/adiftools-dev

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file adiftools-0.1.10-py3-none-any.whl.

File metadata

  • Download URL: adiftools-0.1.10-py3-none-any.whl
  • Upload date:
  • Size: 13.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for adiftools-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 c75356519ca4cb3685108aed105cc2da583db1aafc9db00c0e7dc9d4056f70bb
MD5 dc7cfaefe382bc00dddc00f4de871f22
BLAKE2b-256 03359e7a338b83ed7b3decb452d728c89e088aa651cd78902589c9caf26461a5

See more details on using hashes here.

Provenance

The following attestation bundles were made for adiftools-0.1.10-py3-none-any.whl:

Publisher: publish-to-pypi.yml on JS2IIU-MH/adiftools-dev

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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