Using Python to gather and clean data and used Excel/Spreadsheet(Pivot table, VLOOKUP, Data validation, Conditional formatting, and Charts) to create an interactive dashboard
data:image/s3,"s3://crabby-images/cd74a/cd74a74184f98a436bd574953baeeed4d69065e9" alt="Feel free to use the final dashboard here."
Imaginary situation: My manager wanted to understand the video game market. Although she has some domain knowledge in the gaming industry, she doesn’t know how to manipulate the data. Therefore, she asked me to create an easily used interactive dashboard.
data:image/s3,"s3://crabby-images/9dbd9/9dbd9bf8619b2bc1e9ac680440344214a633f882" alt="Photo by JESHOOTS.COM on Unsplash"
In real life, the managers might give analysts some must-addressed questions and needs beforehand. So, I imagine some questions and needs she might provide. Below are the must-have elements from my imaginary manager:
- The user can choose a specific region and year, and the data and graphs in the dashboard would be altered correspondingly.
- It should contains top 5 game platforms by sales in descending order corresponding to a chosen region and year.
- If the sales of the game platform and genre is above 25%, highlight it automatically.
- It should contain top 5 game genres by sales in descending order corresponding to a chosen region and year.
- It should contain video game sales from the earliest year to the most recent year corresponding to a chosen region.
This dataset contains a list of video games with sales greater than 100,000 copies. It was generated by a scrape of vgchartz.com (from Kaggle).
Let’s start by explaining the whole process in this project:
Step 1: Gather the data using Python (Code)
Step 2: Assess and clean the data using Python (Code)
Step 3: Wrangle the data with Spreadsheet/Excel
Step 4: Create the interactive dashboard with Spreadsheet/Excel
Step 1: Gather the data using Python (Code)
Step 2: Assess and clean the data (Code)
Since it’s a pretty clean dataset already, so in the assessment process, I only found 2 quality issues:
- Missing values in ‘Year,’ ‘Publisher’
- 6761 rows have wrong Global_Sales numbers
Before cleaning, let’s copy the original data first:
df_copy = df.copy()
Cleaning 1: Missing values in ‘Year,’ ‘Publisher.’
Action: delete data without year and publisher because there are not many of them without those data.
df_copy.dropna(axis=0, how='any',inplace=True)
Test
df_copy.info()
data:image/s3,"s3://crabby-images/1b8a0/1b8a07fcb0dcac488d1369568957e06181bd9d6d" alt=""
Cleaning 2: 6761 rows have wrong Global_Sales numbers
Action: Add up ‘NA_Sales,’ ‘EU_Sales,’ ‘JP_Sales,’ and ‘Other_Sales’ and save them into the ‘Global_Sales’ column
df_copy['Global_Sales'] = df_copy['NA_Sales'] + df_copy['EU_Sales'] + df_copy['JP_Sales']+df_copy['Other_Sales']
Test
df_copy[df_copy['Global_Sales'] != df_copy['NA_Sales']+df_copy['EU_Sales']+df_copy['JP_Sales']+df_copy['Other_Sales']].shape[0]
Out[391]: 0
Finally, let’s save it.
# store the file df_copy.reset_index(drop=True) df_copy.to_csv('clean_vgsales.csv')
Step 3: Wrangle the data with Spreadsheet/Excel
Before wrangling, let’s load the clean data(16292 rows, 11 columns) into Spreadsheet, and it looks like this:
data:image/s3,"s3://crabby-images/7609e/7609eac2843dac8f69cfe66128e74ac7e2d571ce" alt=""
Now, let’s wrangle the data to the formats that can be used to create the graphs and tables we want. Let’s start with the needs one by one:
- The manager can choose a specific year and region, and the data and graphs in the dashboard would be altered by them.
To realize this need and given our dataset is not grouped by year or region, so my solution is to use a pivot table to put the year on the row, and region on the column, and then sort it by year in descending order so that it would look like this:
data:image/s3,"s3://crabby-images/6d698/6d698405ef8ebe73029a38ba02ae1c9b131eb877" alt="Check it here"
And to make it choosable, we have to use data validation:
Choose the cell you want to put the options in, then right-click it and scroll down. You will find data validation. In the right second box to the criteria, input the range that you want, so in here, I went to the pivot table that I just created and selected the year from 2020 to 1980(the oldest).
data:image/s3,"s3://crabby-images/72b5e/72b5efabcc54324617040918d2fa4a4c45e0f9f9" alt=""
And we will do the same thing to the region. The result will look like this:
data:image/s3,"s3://crabby-images/9c1b2/9c1b2c0f0a5a9ae6ea1520fb4c6b04ae4805527d" alt="Users can click it and choose the year and region they want"
And since we already have a chosen year and region, I think it would be good also to show the total sales. So I use VLOOKUP() to look up the total sales from the pivot table we just created:
=VLOOKUP(A2,'Year and Sales'!A2:E40, switch($B$2,'Year and Sales'!$B$1, 2, 'Year and Sales'!$C$1, 3, 'Year and Sales'!$D$1, 4, 'Year and Sales'!$E$1, 5),False)
data:image/s3,"s3://crabby-images/5762d/5762d481cb73a929d52fbbcef48ddb43be378ba7" alt="125.63 is in a million. We will specify the currency unit later."
- It should contains top 5 game platforms by sales in descending order in a chosen region and year.
Firstly, remember, we need this to be simultaneously changing by the given year and region, so before we pivot and group it by the game platform, we need to group it by year first and then the game platform and sort it in descending order by the sales:
data:image/s3,"s3://crabby-images/05768/05768b191fc3d803d888411a233b92202be545a2" alt=""
And since we put all the regions altogether, we can’t sort the value by each region separately simultaneously. We need to do this process one by one and copy the pivot table of each region into one combined tab. Here is the result:
data:image/s3,"s3://crabby-images/0c242/0c24223f2c32107c44ad05909fda8228a756b8fe" alt="It is in the 'Top sales by platform in given year and region (Table)' tab."
If you keep scrolling down, you will see North America, Europe, and Global.
In the same tab, I used the filter() function to select the data we want to be given the chosen year and region from our dashboard tab.
=filter($A$2:$D$965, $A$2:$A$965= Dashboard!$A$2, $D$2:$D$965= Dashboard!$B$2)
// this second parameter is to filter by the year selected by user in the dashboard tab, and the third one is to filter by the region also selected by user in the dashboard tab
So, for example. If we select 2016, Europe in the dashboard, it will show:
data:image/s3,"s3://crabby-images/37cf2/37cf2baa47b5733e40f915779b6c1461c220f860" alt=""
And, we don’t need to show Year and Region in the dashboard since it already shows in the dashboard. Therefore, we will use formulas of reference to show the data we want:
='Top sales by platform in given year and region (Table)'!G2
And then copy this and paste to the cells we want to show.
The result will be like this:
data:image/s3,"s3://crabby-images/02fe2/02fe27ba6ed565a3a54f3c1e126e22bff94fdecb" alt=""
We can use this filtered table to create the graph showing the top 5 game platforms by sales in descending order in a chosen region and year.
data:image/s3,"s3://crabby-images/7e41d/7e41d406c9f4ce2cf1a094cb7be6943857dcecf6" alt=""
- If the sales of the game platform and genre is highere than 25% in its region, highlight it automatically.
Let’s show how I did for the platform, and it applies to any other tables.
Select the range that you want to be highlighted, and right-click and then choose Conditional Formatting. It will show this:
data:image/s3,"s3://crabby-images/7f6f2/7f6f2c4d33f0a736f3655b0d96f61e22a2bf2c3f" alt="In this case, I will use greater than and input 0.25 to highlight the data that is higher than 0.25"
Result:
data:image/s3,"s3://crabby-images/749f7/749f752b34315a94a49429262c179e14242a3100" alt="This will automatically highlight the higher than 25% data whenever we change the year or region."
- It should contains top 5 game genres by sales in descending order in a chosen region and year.
Like what we did for the top 5 game platforms by sales in descending order in a chosen region and year. We also need to group the original dataset by year and then genre. And then combine the data of each region one by one into a single table. Here is the result:
data:image/s3,"s3://crabby-images/99355/9935533628887841ea92f98fe57059b364b7eea3" alt="If your scroll down, you will see Japan, Europe, and Global."
And again, I use the filter() function to filter the data by the chosen year and Country. And use formulas of reference to show the data we want. Here is the result:
data:image/s3,"s3://crabby-images/b2264/b2264a920f884c76c8dbf3c585d108365cb8064c" alt=""
Now, let’s use this table to plot "top 5 game genres by sales in descending order".
data:image/s3,"s3://crabby-images/5a424/5a42449d868d07976a4f0cf17155a321d77090e5" alt=""
- It should contains video game sales from the earliest year to the most recent year in a chosen region.
This one is relatively easy. Firstly, I use a pivot table to put the year in the row, and the sales of each region in the column, sort them in descending order by year, and then combine the individual region’s sales by only using sales and region to include the data:
data:image/s3,"s3://crabby-images/e9fac/e9faca7bcf93977c11302c215d314f34c7770969" alt=""
Also, I use filter() to filter it by the given year:
=filter(A2:C157, C2:C157=Dashboard!B2)
And I use a line chart to visualize it!
data:image/s3,"s3://crabby-images/4aaa2/4aaa2a516649b9f7594902db181da4549d81b037" alt=""
Step 4: Create the interactive dashboard
After we have every table and graph we need, we can put all these together and make it tidy and easy to use.
Since there are two tables in the dashboard, so I use titles, which are bold and bigger font size than its data to make it clear:
data:image/s3,"s3://crabby-images/cd9e1/cd9e195ea4b4b8b4457fdaef50c918f81a8a8743" alt=""
data:image/s3,"s3://crabby-images/e2584/e2584c93a9a4999ee831aaa465404acd54b7f8f5" alt=""
And I decide to put the graphs under and beneath each of the two tables. I intentionally made the tables not parallel because it’s hard to separate there are two different tables at first glance. It will be clearer if we put them this way:
data:image/s3,"s3://crabby-images/9a1fc/9a1fc29c7edc28fff03eb20941293146c5523405" alt=""
And, don’t forget about the line chart!
data:image/s3,"s3://crabby-images/81737/817371432742ac3524a868ecf727fc223e68f7ce" alt=""
Finally, let’s make it clear and tidy, and we’re done!
data:image/s3,"s3://crabby-images/1c9f9/1c9f9bfe5a8817fcf07eafb3a18598cabc0589be" alt=""
Thanks for spending your time reading this article.
If your company is hiring data analyst interns, here is my LinkedIn or contact me through my email(yuehhanchen@gmail.com)
If you’re also working in the data science/business Analytics field, feel free to connect with me on Linkedin or give me any feedback by email or comment below!