Skip to main content

CLI tool for Fantasy Premier League analysis - classic and draft formats

Project description

fpl-cli

Fantasy Premier League analysis from the terminal. Classic and Draft formats. Six data sources, one interface.

PyPI Python 3.11+ License: MIT

FPL player scouting table in fpl-cli showing form, xGI, expected goals, availability flags and Fantasy Premier League data

Example output from fpl player — real-time player analysis with form, xGI and availability flags.

Features

  • Multi-source data - FPL API, Draft API, Understat (npxG/xGChain), historical data (vaastav 2022-25 + Core-Insights 2025-26), and football-data.org in one place.
  • Player scouting - Filter by any stat, track xG trends, spot underperformers, check fixture runs.
  • Fixture intelligence - Bayesian difficulty ratings from actual match results, blank/double GW detection, squad exposure analysis.
  • Custom analysis - Captain picks, transfer targets, differentials, waivers, and ILP-optimal squad allocation. Opt-in, off by default.
  • Gameweek reports - Post-GW reviews and league recaps with optional LLM narrative.
  • Draft parity - Most commands work for both Classic and Draft. Waivers cover the free-agent wire.
  • Agent-friendly - --format json with a consistent envelope on key commands. Ready-made agent skills in .agents/skills/.

Quickstart

$ pipx install fplkit
$ fpl init
$ fpl status
$ fpl stats -p MID -s form --available-only

fpl init configures your FPL IDs and optional features. With just an entry ID you get the full data toolkit.

Installation

Requires Python 3.11+.

$ pipx install fplkit

Alternatives: uv pip install fplkit or pip install fplkit.

[!NOTE] Browser scraping (fpl squad sell-prices --refresh) requires the scraper extra and Playwright:

$ pipx install 'fplkit[scraper]'
$ playwright install chromium

Usage

After the Gameweek

$ fpl status                       # GW result, deadline, rank movement, flagged players
$ fpl review --save --summarise    # Full review with LLM narrative
$ fpl league                       # Live league standings
$ fpl league-recap --summarise     # Awards and editorial for the group chat

Scouting Players

$ fpl stats -p FWD -s form -a             # Forwards by form, excluding unavailable
$ fpl player Rice -f -u                   # Deep dive: fixtures + Understat analysis
$ fpl xg                                  # xG/xA analysis, over/underperformers
$ fpl history                             # Career arc across 3 seasons
$ fpl price-history -n 4 -s price_slope   # Bandwagon detection

Before the Deadline

$ fpl squad                        # Squad health: form, injuries, recommendations
$ fpl squad grid -n 8 -w Mbeumo    # 8-GW fixture difficulty grid with a watchlist player
$ fpl fdr --my-squad               # Your squad's blank/double GW exposure
$ fpl preview --save --scout       # Full analysis + BUY/SELL research via LLM

Strategic Planning

$ fpl fdr --blanks                 # Confirmed + predicted blank/double GWs
$ fpl chips timing                 # Rule-based Free Hit / Bench Boost / Triple Captain signals
$ fpl fixtures                     # Next GW fixtures with FDR

Custom Analysis

Off by default. Enable via fpl init or custom_analysis: true in settings.yaml.

$ fpl captain                      # Ranked captain picks (0-100 matchup scoring)
$ fpl targets --min-own 30         # Transfer targets, template tier
$ fpl differentials -t 3           # Ultra-differentials (<3% owned)
$ fpl waivers                      # Free-agent waiver picks with drop suggestions (draft)
$ fpl transfer-eval --out Palmer --in "Salah,Mbeumo"  # Side-by-side comparison
$ fpl allocate --horizon 1         # Free Hit: optimal squad for a single GW
$ fpl ratings                      # Bayesian team strength ratings from match results

Enabling custom analysis also enriches other commands: fpl stats gains --value columns, fpl xg adds Value Picks, fpl fdr upgrades to Bayesian FDR with ATK/DEF split.

JSON Output

Commands with --format json emit a consistent envelope:

{
  "command": "stats",
  "metadata": {"gameweek": null, "format": "classic", "custom_analysis": true},
  "data": [...]
}
$ fpl stats --format json -p MID -s expected_goal_involvements
$ fpl status --format json
$ fpl fdr --blanks --format json

Configuration

Run fpl init to configure interactively. Settings stored in your platform's config directory (override with FPL_CLI_CONFIG_DIR).

Required: FPL classic entry ID or draft league + entry IDs.

Feature What it enables
Custom Analysis Captain, targets, differentials, waivers, allocate, ratings, value scores, Bayesian FDR
League ID Standings, fines, league recaps
LLM providers --summarise and --scout flags (Perplexity, Anthropic, OpenAI, or any compatible API)
FPL credentials fpl squad sell-prices (browser scraping)
FOOTBALL_DATA_API_KEY League table in fpl review
# LLM providers (for --summarise and --scout)
export PERPLEXITY_API_KEY="your-key"    # Research role
export ANTHROPIC_API_KEY="your-key"     # Synthesis role

See Command Reference for the full settings.yaml schema and LLM provider setup.

Development

$ git clone https://github.com/rossgroomio/fpl-cli.git
$ cd fpl-cli
$ python3 -m venv .venv && source .venv/bin/activate
$ pip install -e ".[dev]"
$ fpl init
$ ruff check fpl_cli/    # Lint
$ pyright fpl_cli/       # Type check
$ pytest tests/          # Tests

[!NOTE] Football data provided by the Football-Data.org API. Player and fixture data is property of the Premier League. Expected goals data is property of Understat. Historical data from vaastav/Fantasy-Premier-League (MIT, 2022-25) and olbauday/FPL-Core-Insights (2025-26+). This tool fetches data at runtime and does not redistribute third-party data.

[!WARNING] Browser scraping (fpl squad sell-prices) uses your FPL login to read sell prices. Automated access may violate FPL website terms - use at your own risk.


Command Reference | Custom Analysis Guide | Architecture | Agent Tools & Skills

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

fplkit-1.2.1.tar.gz (739.1 kB view details)

Uploaded Source

Built Distribution

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

fplkit-1.2.1-py3-none-any.whl (308.2 kB view details)

Uploaded Python 3

File details

Details for the file fplkit-1.2.1.tar.gz.

File metadata

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

File hashes

Hashes for fplkit-1.2.1.tar.gz
Algorithm Hash digest
SHA256 5a905678b999a9a62b1211b48d7811750fa3c2ff8ee51a9b62f31d2e7d11b9ff
MD5 ce5b4271efc9d7eae926351a416d583f
BLAKE2b-256 9b0ec2df64ba46796fc132f2f86bc8214fa4addc0d21d100b1b0a8d4b4e52786

See more details on using hashes here.

Provenance

The following attestation bundles were made for fplkit-1.2.1.tar.gz:

Publisher: release.yml on rossgroomio/fpl-cli

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

File details

Details for the file fplkit-1.2.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for fplkit-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 db54ec6249bdf4a9747f9597ec26d48c97ad1406707f369bf3ffb8fc76709203
MD5 7a57c86c3aae84a6245ff56a2736e416
BLAKE2b-256 ef8af1295a953b87b1d5eaa64455c75c0f9ab586dd7e11ada915e315b4c9d6d2

See more details on using hashes here.

Provenance

The following attestation bundles were made for fplkit-1.2.1-py3-none-any.whl:

Publisher: release.yml on rossgroomio/fpl-cli

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