/football_data_analysis

Data Analysis of Serie A, La Liga, Bundesliga and Premier League to identify trends and possible outcomes for upcoming matches

Primary LanguageJupyter Notebook

Football Data Analysis

By leverging historical data from the current season, it is possible to identify trends, recurring results and behaviors for the different teams. We divide the standing into groups and analyze how the various teams perform against that group, both in home and away matches.

Combining these insights with an intuitive visualization it is possible to use this notebook to have an overview over possible trends, past key metrics to try to predict the outcome of an upcoming match.

How to use the notebook

The magic happpens in this notebook.

The first part of the notebook precalculates metrics for the different dimensions, teams, groups, home/away etc.

Among others:

After these sections comes the interesting analysis for a specific match.

It is enough to change the teams and competion under Match Analysis and then execute all cells and get the various metrics.

Just scroll though the code to see intuitive graphs such as these ones.

Example 1: Wins against teams from the same standing group

Wins VS Group

Example 2: Result trends for a specific team

Result Trend - Leicster

Example 3: No Goal results against teams from the same standing group (home or away)

NoGoal

Fun Exploration

I use this notebook to investigate outliers, particular trends, exceptionally performing teams. Just for fun. For example, out of all the considered championships, we can look at metrics such as:

  • Teams with highest delta average goals for-against
  • Teams with highest delta average goals for-against, with top tier teams in their championship
  • Teams with highest NO GOAL percentage of matches
  • Teams with highest percentage of GOAL matches
  • Teams with imporvements in NO GOAL looking at recent trends

Technicalities

Env file

It is also necessary to create a .env file with a token to query the api.football-data.org APIs.

The file is a simple text file to be places in the root folder of the project with this structure:

footaball_data_token=<token>
season=<current season>

Pratical Steps to Run the Project

To run the project locally is it simple to use Docker. Create a container to host the jupyter notebook app and spin it up.

Create working container to run jupyter

docker build -t pypipenv39 .

Execute container to run jupyter

docker run -p 8888:8888 -v $(pwd):/workdir pypipenv39