IPL(Indian Premier League) Dashboard using Flask, AmCharts, and MongoDB
Introduction
- IPL as we all know is one of the most decorated cricket premier leagues in the world.
- In this blog, we are going to take the IPL dataset from 2008 to 2020.
- We are going to download that dataset from Kaggle – https://www.kaggle.com/patrickb1912/ipl-complete-dataset-20082020
- We are going to store this dataset in our database, we will be using MongoDB as our database.
- We will be using the Flask framework for our application.
- For creating the visualization charts we will be using AmCharts4.
- For MongoDB references, you can check out – https://statusneo.com/mongodb-introduction/
- Let’s begin creating our IPL visualization application.
Data Cleaning
- In this task, we are going to clean our dataset.
- Once you have downloaded your dataset, you will be able to see 2 files there- IPL Ball-by-Ball 2008-2020.csv, IPL Matches 2008-2020.csv
- For this project, we will work only on the matches dataset.
data:image/s3,"s3://crabby-images/a9199/a9199fee9154f46ca113a8766da27b11be032e67" alt=""
- This is how our dataset look likes.
- So for cleaning purposes let’s first remove the null values from the dataset.
- We will be removing rows having null values in team1 or team2 column.
data:image/s3,"s3://crabby-images/5ddf8/5ddf82db8349f5e752ba91bec72c398ddf1fdb17" alt=""
- This is how our dataset looks after cleaning, although no rows are removed because there were no null values present there.
- But I will prefer to do this step as it helps in cleaning the data if there is some Null value present.
- Let’s create this CSV file to matches.csv and store it in the same directory.
data:image/s3,"s3://crabby-images/da22b/da22b59ba94ace247aed5b321d380ccf0f89d9f5" alt=""
Data Upload to MongoDB Cluster
- MongoDB is going to be our primary database for this project.
- We are going to use MongoDB cloud and the free cluster that they provide.
- For uploading the data we will do it using our python code, with the help of pymongo library.
data:image/s3,"s3://crabby-images/7fe41/7fe4145a2f0cf6ee1dd91a04b0c54ba1ae2f66ed" alt=""
- After creating your account on MongoDB cloud you will be redirected to a window that looks like this.
- For finding the connection string to the cluster you can click on the connect button and select the application to get your link.
data:image/s3,"s3://crabby-images/ed1bb/ed1bb32bebb60250f6c6957c33e8e2c6fb771c68" alt=""
- Code to upload code to the MongoDB cluster is –
data:image/s3,"s3://crabby-images/05a96/05a96a46848471e8fd1071dc58a4b17dd866d324" alt=""
- Let’s see the MongoDB cloud console and see how the data is looking there.
data:image/s3,"s3://crabby-images/97443/974434b2ee1fb132039fe3c98dc8ef7646d311a0" alt=""
- So now our data has been cleaned and uploaded to the database, let’s begin with the application.
Application Using Flask
- Let’s start creating our flask application.
- We are going to follow the generic structure of creating a flask application.
- We will be having a requirement.txt file where all the packages and their versions will be provided.
- Then we will be having an src folder that will be having all the APIs and the backend-related stuff.
- In the templates, we will be having our UI templates.
data:image/s3,"s3://crabby-images/eb288/eb2881e4a4f43ca31c954466fa663b85daa9043a" alt=""
- This is how the structure of our project looks like.
- We need to run pip install -r requirements.txt, it will install all our required packages.
data:image/s3,"s3://crabby-images/2c9cb/2c9cbeeb834e0305327396b72f14b0239a2413f4" alt=""
- Lets run our app, by running the app.py file, in this file we created the connection with MongoDB.
- app.route is the URL that will initiate the function, by default the home page will be opened.
data:image/s3,"s3://crabby-images/fdd62/fdd624cdfebb5e9d0e472f96d1165f969461547a" alt=""
data:image/s3,"s3://crabby-images/90d33/90d3398167564e0656d8ef6716443c337fa90054" alt=""
- https://www.amcharts.com/docs/v4/ , this is the link to the amcharts4 official documentation that we are going to use in our project.
- Let’s create our homepage, so on our homepage, we want to have 3 charts.
- In the first half of our page, we want to show the team’s bar chart with their wins.
- In the second half, we want to show two charts.
- One Pie chart of teams with their toss wins.
- Other charts of players with their man-of-the-match awards.
- Let’s create our home_page file in the src directory.
- And also create an index.html in templates. It’s a dummy template we have taken from the bootstrap official website.
- Let’s have the bar charts and pie chart code from amcharts4 and add it to our js directory under static.
data:image/s3,"s3://crabby-images/6ecc4/6ecc49b40280257322755e8d0d49739d80a33739" alt=""
- In our src folder let’s add the code for fetching the data from MongoDB.
- we will be bringing the data for the team wins, toss wins, and player of the match awards.
data:image/s3,"s3://crabby-images/b3d50/b3d50ef5e9e54d58e0eee77a40aaeb3d6ddb60b4" alt=""
data:image/s3,"s3://crabby-images/76329/7632956407c0b3666da48b6ca4f58fcb1494a8cc" alt=""
- In the templates, file let’s add the response of our dataset.
data:image/s3,"s3://crabby-images/8523e/8523e824d3584f12a2b489c64a6352288a664713" alt=""
- I am not covering all the code, because it will become very long then.
- So I will be sharing my GitHub link to this code.
- Now let’s start our application and see what our work looks like..
data:image/s3,"s3://crabby-images/bf58c/bf58c34e0e5f07a8702f4ff860c57fe5983c8d13" alt=""
- Now our app is up, so let’s try our home page.
data:image/s3,"s3://crabby-images/f0a6c/f0a6cf5bed87135e44761c7697bfd742511d78eb" alt=""
Conclusion
- And here it is, our home dashboard is ready, if you want to have more charts or more data analysis go ahead the stage is set now.
- So we collected the data, cleaned it, uploaded it to our database, created our flask application, used amcharts there, and visualized the dataset.
- The whole application code is available at GitHub at – https://github.com/Utkarsh731/IPL
- For any queries feel free to contact me- at [email protected], https://www.linkedin.com/in/utkarsh-shukla-1520a8255/
- Still Curious? Visit my website to know more!
- For more interesting Blogs Visit- Utkarsh Shukla Author
0 Comments
Add Comment
You must be logged in to post a comment.