Skip to main content

Fantasy football league simulation and optimization tool.

Project description

fantasyfb

Fantasy football league simulation and optimization toolkit. Pulls projections from nflverse data, syncs roster state from a Yahoo Fantasy league, and runs Monte Carlo season simulations to value pickups, trades, and draft picks.

Install

pip install fantasyfb

For local development:

git clone https://github.com/tefirman/fantasyfb.git
cd fantasyfb
pip install -e ".[dev]"

Python 3.10+ is required.

Quickstart

import fantasyfb as fb

league = fb.League(name="My Team")
schedule_sim, standings_sim = league.season_sims(postseason=True)
print(standings_sim[["team", "wins_avg", "playoffs", "winner"]])

fb.League(name=...) reads from the Yahoo Fantasy API, so you'll need oauth2.json (and .env with CONSUMER_KEY / CONSUMER_SECRET) set up alongside the script. See the yahoo_oauth docs for a walkthrough.

Command-line tools

After install, four entry points are on your PATH:

Command Source Use
fantasyfb fantasyfb.league:main Weekly projections + lineup analysis
snake-draft fantasyfb.drafts.snake:main Live snake-draft cockpit
salary-cap-draft fantasyfb.drafts.salary_cap:main Live salary-cap (auction) draft tool
draft-prep fantasyfb.drafts.prep:main Pre-draft tiers / VORP / mocks
# Weekly run for a team
fantasyfb --team "My Team" --sims 1000 --adds --drops

# Pre-draft analytics
draft-prep tiers --team "My Team"
draft-prep mock --team "My Team" --adp ADP.csv --my-pick 7 --sims 50

# Draft-day cockpit
snake-draft --team "My Team" --adp ADP.csv
salary-cap-draft --team "My Team"

Run any command with --help for the full option list.

Public API

from fantasyfb import (
    League,                            # main entry point
    FantasyScorer,                     # scoring rules -> points
    MatchupModel, ProjectionEngineV2,  # projection internals
    LineupOptimizer,
    SeasonSimulator, ScheduleManager,
    NflreadpyProvider,                 # default data backend
)

Lower-level utilities live in submodules and can be imported directly:

from fantasyfb.drafts.tools import compute_vorp, assign_tiers, MockDraft
from fantasyfb.drafts.snake_cockpit import build_board, view_best
from fantasyfb.sim.backtest import run_backtest, evaluate
from fantasyfb.io.excel_exporter import FantasyExcelExporter
Subpackage Purpose
fantasyfb.league Top-level League class
fantasyfb.configs League / scoring presets
fantasyfb.drafts Snake, salary-cap, prep, shared draft math
fantasyfb.data Yahoo client + nflverse providers
fantasyfb.scoring Scoring, lineup optimization, matchups
fantasyfb.projections V1 / V2 projection engines, fitter
fantasyfb.sim Season simulation, backtests, schedule
fantasyfb.analysis WAR, move analysis
fantasyfb.io Excel export

Development

pip install -e ".[dev]"
pytest                       # full test suite
python -m build              # produce sdist + wheel under dist/

The tests/ directory pulls a small slice of nflverse parquet data on first run; subsequent runs are cached locally.

License

MIT. See LICENSE.

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

fantasyfb-0.4.0.tar.gz (142.0 kB view details)

Uploaded Source

Built Distribution

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

fantasyfb-0.4.0-py3-none-any.whl (116.8 kB view details)

Uploaded Python 3

File details

Details for the file fantasyfb-0.4.0.tar.gz.

File metadata

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

File hashes

Hashes for fantasyfb-0.4.0.tar.gz
Algorithm Hash digest
SHA256 61806eb2ef3f287974f469f83daa52e3f4ecc283c1a89633571395a8e90f799a
MD5 ae311604628595d91a52345522b8b600
BLAKE2b-256 8a4f1d99db8a0c9cc92cdcbc12dc603b0d9a170c1225acd586df6fecc4705b40

See more details on using hashes here.

Provenance

The following attestation bundles were made for fantasyfb-0.4.0.tar.gz:

Publisher: publish.yml on tefirman/fantasyfb

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

File details

Details for the file fantasyfb-0.4.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for fantasyfb-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 91657fec69a8868dce44daf48f619418945d8cc216ffb686e03b42ccb20722f5
MD5 2eefb6f84e84b013e3eecd3b8ab80631
BLAKE2b-256 5524544442a2b14153770fd02c16c3171ceb945a998cffa5944d167416b6e745

See more details on using hashes here.

Provenance

The following attestation bundles were made for fantasyfb-0.4.0-py3-none-any.whl:

Publisher: publish.yml on tefirman/fantasyfb

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