Skip to main content

No project description provided

Project description

LenexPy

Python toolkit for reading and writing Lenex 3.0 swimming data (.lef/.lxf). Models and validation follow the official Lenex technical documentation (Version 3.0, 4 Mar 2025) — see https://wiki.swimrankings.net/images/6/62/Lenex_3.0_Technical_Documentation.pdf.

What it does

  • Decode/encode Lenex XML (.lef) and zipped Lenex (.lxf).
  • Pydantic + pydantic-xml data models aligned with the 4 Mar 2025 spec (required/optional attributes, timing modes, meet/session/event fields, etc.).
  • JSON helpers to build Lenex objects and emit .lef/.lxf.

Install

pip install lenexpy

Quick start

from lenexpy import fromfile, tofile

lenex = fromfile("meet.lxf")      # .lxf / .lef / .xml
tofile(lenex, "out.lxf")
tofile(lenex, "out.lef")

Work with bytes directly:

from lenexpy.decoder.lef_decoder import decode_lef_bytes
from lenexpy.decoder.lef_encoder import encode_lef_bytes
from lenexpy.decoder.lxf_decoder import decode_lxf_bytes
from lenexpy.decoder.lxf_encoder import encode_lxf_bytes

lenex = decode_lef_bytes(xml_bytes)
xml_bytes = encode_lef_bytes(lenex)

lenex = decode_lxf_bytes(lxf_bytes)
lxf_bytes = encode_lxf_bytes(lenex, "meet.lxf")

Build Lenex from JSON

scripts/parser.py can create Lenex objects from JSON and write Lenex files.

from scripts.parser import create_lenex_from_json_file
from lenexpy import tofile

lenex = create_lenex_from_json_file("meet.json")
tofile(lenex, "meet.lxf")

Minimal JSON shape:

{
  "version": "3.0",
  "constructor": {
    "name": "Bot",
    "version": "1.0.0",
    "contact": {"email": "bot@example.com"}
  },
  "meet": {
    "name": "Test Meet",
    "city": "City",
    "nation": "RUS",
    "sessions": [
      {
        "number": 1,
        "date": "2025-01-01T00:00:00",
        "events": [
          {
            "eventid": 1,
            "number": 1,
            "swimstyle": {
              "distance": 50,
              "relaycount": 1,
              "stroke": "FREE"
            }
          }
        ]
      }
    ]
  }
}

Tests

pytest

Fixture-based round trips live in tests/fixtures. Some third-party fixtures may xfail if they are not spec-conformant (e.g., missing required IDs).

Build

python -m build

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

lenexpy-3.1.1.tar.gz (18.1 kB view details)

Uploaded Source

Built Distribution

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

lenexpy-3.1.1-py3-none-any.whl (37.6 kB view details)

Uploaded Python 3

File details

Details for the file lenexpy-3.1.1.tar.gz.

File metadata

  • Download URL: lenexpy-3.1.1.tar.gz
  • Upload date:
  • Size: 18.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.4.1 CPython/3.11.15 Linux/6.17.0-1018-azure

File hashes

Hashes for lenexpy-3.1.1.tar.gz
Algorithm Hash digest
SHA256 349422f9f42330bf8732d8392e225a6341bcacf9c9196418cde42ecd38ecd090
MD5 51dfaf674f80195e46b96da1950de47b
BLAKE2b-256 717709c50bdded3165bce100f6a7642bba666564dc99e11af45779a0063f43dc

See more details on using hashes here.

File details

Details for the file lenexpy-3.1.1-py3-none-any.whl.

File metadata

  • Download URL: lenexpy-3.1.1-py3-none-any.whl
  • Upload date:
  • Size: 37.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.4.1 CPython/3.11.15 Linux/6.17.0-1018-azure

File hashes

Hashes for lenexpy-3.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e6edf59b090c66f8687396b016824905e5a23869adc538a26e7dab9862ddcb51
MD5 70c50777e487584eb14b90d28d1690ca
BLAKE2b-256 21385c435bbb86ecd91a8bf760fc93d4adc3af5be5aa01b02c814b7c8c3ff181

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