2022: Week 28 - Solution


Solution by Tom Prowse and you can download the workflow here


This week we continued our fundamental challenges by focussing on a common problem in data preparation. That problem involves including data about something that doesn't happen. Our example is we're trying to identify the days when there were no sales at our stores. Let's see how we solved the challenge.

Step 1 - Days with no sales

First up we want to convert our date field from a datetime to just a date. This can be done by pressing on the calendar and clock icon in the top left of the field in the profile pane, and then changing to a Date option.

We can now go and add some new rows for days when there were no sales. For this use the 'New Rows' step to help us.

After bringing the New Rows into our workflow, we need to set this up so that we are creating a new row from our minimum to maximum sale date: 


This will allow us to fill in the missing days and will create a new row for each of them. Our table should look something like this, where if there are no sales on that day, the row should have 0s and nulls: 


We are only interested in the days where there were no sales, so we can filter the Sale Value and keep only 0:



Step 2 - Days of the Week

Now we have identified all of the days where there are no sales, we can now do some further analysis based on which days of the week this occurs most regularly.

First we can remove any fields that we no longer require. This includes OrderID, Sale Value, Product Name, Store Name, Region, and Scent Name. We should be left with just the Sale Date field.

Using the Sale Date we can duplicate this by clicking on the three dots and then choosing duplicate. Once duplicated, we can use the Convert Dates feature to convert one of the date fields in days on the week: 



Now we should have two fields, Day of the Week and Sale Date


The final steps for the challenge are to total the numbers by each day. For this we can use an aggregate step where we group by Day of the Week and CountD Sale Date 


The final task is to rename Sale Date to Number of Days and then we are ready to output our table: 


You can download the full output here

After you finish the challenge make sure to fill in the participation tracker, then share your solution on Twitter using #PreppinData and tagging @Datajedininja@JennyMartinDS14 & @TomProwse1

You can also post your solution on the Tableau Forum where we have a Preppin' Data community page. Post your solutions and ask questions if you need any help! 

Popular posts from this blog

2023: Week 1 The Data Source Bank

2023: Week 2 - International Bank Account Numbers

How to...Handle Free Text