Skip to main content

Lightweight Python SDK for sports data — football, F1, NFL, NBA, WNBA, NHL, MLB, tennis, CFB, CBB, golf, volleyball, prediction markets, betting analysis, and news

Project description

sports-skills

https://sports-skills.sh

A lightweight, zero-config Python SDK and CLI for live sports data and prediction markets.

Built natively for AI agents, but works perfectly as a standalone Python library for developers. Wraps publicly available sports data sources and APIs into unified, deterministic commands.

Zero API keys. Zero signup. Just works.


📦 Installation

Install as a global CLI tool (recommended for agents):

uv tool install sports-skills
# or
pip install sports-skills

Base install includes all sports modules.

Install as a Python library:

uv add sports-skills
# or
pip install sports-skills

Optional extras:

pip install "sports-skills[all]"
pip install "sports-skills[dev]"

⚡ What's Included

  • Football (Soccer): ESPN, Understat, FPL, Transfermarkt — 21 commands across 30 leagues
  • US Sports: NFL, NBA, WNBA, NHL, MLB, College Football (CFB), College Basketball (CBB) — live scores, standings, depth charts, injuries, and leaders
  • Tennis: ATP and WTA tournament scores, rankings, calendars, and player profiles
  • Golf: PGA, LPGA, and DP World tour scorecards and leaderboards
  • College XC/TF: NCAA cross country and track & field — athlete profiles, personal records, meet results, and news via The Stride Report
  • Volleyball: Nevobo — Dutch volleyball (Eredivisie, Topdivisie, Superdivisie) standings, schedules, results, clubs
  • Racing: Formula 1 (via FastF1) — lap times, telemetry, and race results
  • Prediction Markets: Polymarket & Kalshi live odds and order books
  • News: Multi-sport news aggregators

💻 CLI Usage

The package exposes a sports-skills binary.

List all supported sports:

sports-skills --help

List commands for a specific sport:

sports-skills nfl --help

Execute a command:

sports-skills nfl get_scoreboard --date 2026-02-24
sports-skills football get_current_season --competition_id premier-league
sports-skills polymarket get_markets --query "super bowl"
sports-skills news fetch_items --query "Lando Norris" --limit 5
sports-skills xctf get_news --limit 5
sports-skills xctf search_athlete --name "Jane Hedengren" --school "UT_college_f_BYU"

All CLI output is printed as strict JSON, making it perfect for AI agents (Claude, GPT, Gemini) to parse and reason over.


🐍 Python SDK Usage

You can use the exact same commands directly in your Python code:

from sports_skills import nfl, football, polymarket, xctf

# Get live NFL scores
scores = nfl.get_scoreboard(date="2026-02-24")
print(scores["data"]["events"])

# Get Premier League standings
table = football.get_season_standings(season_id="premier-league-2025")
print(table["data"]["standings"])

# Fetch live odds from Polymarket
markets = polymarket.get_markets(query="bitcoin")
print(markets["data"]["markets"])

# Get latest NCAA XC/TF news from The Stride Report
news = xctf.get_news(limit=5)
print(news["data"]["articles"])

# Look up an athlete's PRs
profile = xctf.get_athlete_profile(athlete_id="9230145", school="BYU", name="Jane_Hedengren")
print(profile["data"]["prs"])

🏗️ AI Agent Integration

sports-skills is built on the Anthropic Level-3 Agent capability spec. Every command is deterministic and automatically generates its own JSON Schema.

To extract the OpenAI/Anthropic compatible tool schema for any module:

from sports_skills import nfl
import json

# Returns a list of dicts formatted exactly like Anthropic/OpenAI tools
schema = nfl.generate_schema()
print(json.dumps(schema, indent=2))

License

MIT

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

sports_skills-0.26.0.tar.gz (644.6 kB view details)

Uploaded Source

Built Distribution

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

sports_skills-0.26.0-py3-none-any.whl (202.6 kB view details)

Uploaded Python 3

File details

Details for the file sports_skills-0.26.0.tar.gz.

File metadata

  • Download URL: sports_skills-0.26.0.tar.gz
  • Upload date:
  • Size: 644.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sports_skills-0.26.0.tar.gz
Algorithm Hash digest
SHA256 f5597c90d68fb99ad61319e08d7c76e31e35d029b9adc302e3f7bc8072ac4e28
MD5 6ad703353e58041d884516c140e94e56
BLAKE2b-256 3a22ae71343cecb07f2c349ee0500de24f5d6092dc5f2f2c36c3ec02b34dd3d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for sports_skills-0.26.0.tar.gz:

Publisher: publish.yml on machina-sports/sports-skills

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

File details

Details for the file sports_skills-0.26.0-py3-none-any.whl.

File metadata

  • Download URL: sports_skills-0.26.0-py3-none-any.whl
  • Upload date:
  • Size: 202.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sports_skills-0.26.0-py3-none-any.whl
Algorithm Hash digest
SHA256 98956c1aecc4149990b02e77ca504cc342bf1be087bf8f54e0f5011878cb052e
MD5 c13a77fa5fa61c414f01665f3265389c
BLAKE2b-256 99041fd70b5b7a8ac0d5024871e917dfab4ef2631427ba67aa9b215a94ce139b

See more details on using hashes here.

Provenance

The following attestation bundles were made for sports_skills-0.26.0-py3-none-any.whl:

Publisher: publish.yml on machina-sports/sports-skills

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