Skip to main content

Instant stats for any fantasy football league.

Project description

leeger logo

Instant stats for any fantasy football league.

Last Commit
End-to-end Tests Unit Tests Formatting Check

Table of Contents

Overview

This library allows you to take data from an existing fantasy football league and get instant stats from that league into either a Python script or an Excel spreadsheet.

This library supports multiple fantasy sites AND manual league data input.

Python stats will be stored in these objects:

Excel sheets will include:

  • A tab for each year with team stats
  • A tab for each year with matchup info
  • A tab for all-time with team stats
  • A tab for all-time with matchup info
  • A tab for all-time with owner stats


The main idea behind this library is:

  1. Load stats into a League object
  2. Pass this League object into various library methods to extract stats


For guides on how to use this library, see the information under Supported League Loaders and in the example folder.

Quickstart Guide

1. Download Python

  • Download the latest supported version of Python here.
  • Currently, Python version 3.10+ is supported

2. Create a basic Python file to use this library

  • Create a file that ends in the extension ".py"
    • Example: my_script.py

3. Download this library

  • Navigate in your terminal to the directory where you created your Python script in Step 2
  • Run the command pip install leeger
    • If you do not have pip installed, you will need to install it

4. Download your league data using a league loader

  • Find the site/s you use for fantasy football here
  • Follow the Setup Documentation
  • Once you have everything you need for your selected site/s, use the code examples found here for your specific site/s to download your league data
    • You can put the code inside the Python script you created in Step 2
  • If you have leagues that are continued in multiple sites, you can pull from multiple sites and add the League objects together to combine the different sites
    • An example of this can be found here

5. Run your script

  • Navigate in your terminal to the directory where you created your Python script in Step 2
  • Run the command py my_script.py
    • Replace my_script.py with whatever you named your script in Step 2

6. Load your league stats into Excel

  • Slightly alter your script from Step 2 to include a function call to load your league stats into Excel
  • Follow this example
  • Make sure that you are passing the League object that you pulled from the league loader/s into the function call to put your stats into Excel

FAQ

Question: I'm getting this error when I run my script:

TypeError: dataclass() got an unexpected keyword argument 'kw_only'

Answer: This error occurs when the Python version you are using is not 3.10 or greater.
Make sure you are using Python version 3.10 or a newer version.


Q: How do I use this library to pull stats from my online fantasy league?

A:

  1. Find your fantasy site here and ensure you have everything you need for the site you are using
  2. Follow the example code snippets for your fantasy site to load the League object

Q: How can I get stats into Excel once I have my League object?

A: Follow this example code.


Q: Can I combine years from different fantasy sites that are loaded as separate League objects into a single League object?

A: Yes, the League object supports addition (+) to combine multiple league objects.
An example of this can be found here.


Q: Can I disable validation on my League object?

A: Yes. While it is not recommended that you disable this, as validation ensures the stats are calculated properly, disabling validation can be done by passing validate=False into any method that takes a League object OR any loadLeague() method from a League Loader.

Installation

Use the package manager pip to install.

pip install leeger

Supported League Loaders

Sites that you can automatically load your league data from.

Name Website Supported Setup Documentation
ESPN https://www.espn.com/fantasy/football/ :heavy_check_mark: ESPN :page_facing_up:
Fleaflicker https://www.fleaflicker.com/ :heavy_check_mark: Fleaflicker :page_facing_up:
MyFantasyLeague http://home.myfantasyleague.com/ :heavy_check_mark: MyFantasyLeague :page_facing_up:
NFL https://fantasy.nfl.com/ :x: :x:
Sleeper https://sleeper.com/fantasy-football/ :heavy_check_mark: Sleeper :page_facing_up:
Yahoo https://football.fantasysports.yahoo.com/ :heavy_check_mark: Yahoo :page_facing_up:

If a fantasy site you use is not listed here and you would like it to be, please open an issue.

Stats Explained

Stats used in this library are documented here.

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

Development

Run these commands from the root folder

  • Format Code: ./main fmt
  • Run Unit Tests: ./main test
  • Generate Coverage Report: ./main cov

Running Tests

Run the following command from the root folder:

  pytest

License

MIT

Credit

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

leeger-2.6.1.tar.gz (142.2 kB view details)

Uploaded Source

Built Distribution

leeger-2.6.1-py3-none-any.whl (216.5 kB view details)

Uploaded Python 3

File details

Details for the file leeger-2.6.1.tar.gz.

File metadata

  • Download URL: leeger-2.6.1.tar.gz
  • Upload date:
  • Size: 142.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.0

File hashes

Hashes for leeger-2.6.1.tar.gz
Algorithm Hash digest
SHA256 95aaa54ce15fa84f53c7ff5dc07cfde4b4f0597759d639c8ccd99313d02f09b7
MD5 fdfa438ea6fc3a4d3e126dc72d3fc518
BLAKE2b-256 dcb0cf4378f3701bd9cd1fe1fe8a3d2f49509cc6135eebc54214787661007571

See more details on using hashes here.

File details

Details for the file leeger-2.6.1-py3-none-any.whl.

File metadata

  • Download URL: leeger-2.6.1-py3-none-any.whl
  • Upload date:
  • Size: 216.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.0

File hashes

Hashes for leeger-2.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5e6bdff5cb1968d34eab187a60cc035d6082517636bb1c2c2b88cbb11fbad71f
MD5 6348084784cec829744a3906b9be9240
BLAKE2b-256 abbf4c9bf9f47c4e4716ac19149174b7b299118ac0be91a64992f1ebdf241519

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page