Comparing Sales of One Product with Another [Excel Techniques]

Share

Facebook
Twitter
LinkedIn

This is a guest article by Theodor on how to Compare Sales of One Product with Another

Ok, now here’s one for you.

Suppose you’d like to come up with a sales report on different products, comparing their evolution on the same period of different years (say Jan ’09 vs. Jan Jan ’10). At the same time, you’d like to keep an eye on their yearly trend (entire 2009 vs. entire 2010).

No big deal, you’ll say, but here’s the twist: the products have not been available for the entire time span taken into consideration. Let’s say you’ve only had Product 1 available for sale for Feb ’09 onwards, while it had been discontinued from October ’10. If you’re really looking for a Like-For-Like (LFL) comparison, you’d only want to compare the months where you have data for both years. It’s false to claim you’ve had a sales boost of 300% when you entered the market with Product X in October 2009, selling 1000 units over 3 months and compare that to the full results of 2010, when you’ve sold 3000 units. In the first scenario you were averaging some 333 units/month, while later you’ve dropped to a mere 250/month. Nothing to brag about there, is it?

Ah, but we also have different product classes. One is aimed for the high-profile buyer (A-Class products), the second for the middle level (B-Class) and so on. Given that different products were added to each class’s portfolio and then later discontinued, we should see the total LFL development of each product class in the same graphical representation.

Hold on another second. One country is defining its quarters as Jan-Mar, Apr-Jun etc, while other might relate a quarterly result to a specific day in the company history (such as the company launch date, or since the new CEO took over or whatever). Wouldn’t it be nice to be able to compare equivalent datasets in any user-defined time span?

So how do you compare sales of one product with another?

Now I’ve always said that the second hardest thing mankind has ever done was to send men on the Moon and safely return them home. That’s only because the MOST difficult thing in the world has become to compare apples with apples. There are so many subtle differences between one dataset and the other (even though they both relate to the same source), that if one reporting template is to have a long life, it should first and foremost come with the built-in ability to allow the end user to drill down through the data and change criteria in order to get relevant results for today’s issue. And all that will change tomorrow, as there will lay a new and unexpected issue on the table.

With that in mind, when I create my templates I follow the self-made golden rule (which later I found many others have applied for themselves long before I knew Excel ever existed) – keep the raw data in one sheet, preferably hidden; use a second sheet for calculation, ALWAYS hidden, and provide a simple and useful graphical interface for the end-user in the third sheet. This will avoid any mishaps such as “Could you please put your formulas back in, I donno which button I pressed and….!!”

Comparing Sales of One Product with Another – Demo:

First see the demo of this technique. Then, we can learn how I created it.

Comparing Sales of One product with Another - Demo

Coming to the attached example – which only works in Excel 2007 and later, by the way:

  • Your data is in sheet ‘data’, ordered by product and timeline (Jan-Dec, 2009 and 2010). I’ve created the values using the =randbetween() formula, and then copy-pasted the values only so they will not change anymore.
  • To keep things more clear, I’ve placed the calculation formulas in the same sheet as that with the graph, just so you can compare values and figure out formulas more quickly, without having to switch between sheets all the time.

Comparing Sales - Data

How the Sales Comparison Chart is made?

Now, to bring up values of a particular product, I’ve created a list in C44:C70 (values in column B are just for guidance). We can compare two products, which can be chosen from a couple of drop-down boxes linked to cells B6 and B8. Here’s where the values in column B help: basically, they tell me which item index from the drop-down corresponds to a product. I then placed the same item indexes in data!A7:A46. This is all because I am lazy and I find the sumifs() formula a blessing: all I have to do now is to add up the results that correspond to (1) the chosen Product in the drop-down, which is looked up by the index, and (2) the year, which is in data!E6:E45. [More on INDEX Formula]

How does the sales comparison chart work

An alternative in Excel 2003 would have been to concatenate the value of “Product 1″&”2009” for example, to get a unique identifier and not return the sales value of 2010 by mistake. Then vlookup() after the concatenated value. [Related: How to lookup based on multiple conditions]

These calculations are placed in ‘Yr sls’!F51:Q54. Note there’s an initial IF() there, to only display the values if the respective month is selected. There are two sliders up in the second row, which can help you ‘cut’ your desired portion of the year for comparison.

‘Yr sls’!F61:Q68, using sumifs() again, I added the sales values for each product class. Finally, in ‘Yr sls’!F45:Q48 are the final calculation, where if an item index lower than 8 (corresponding to Product 1) is selected, the values in F61:Q68 are brought up, else the values in F51:Q54.

So now we see our resulting values above the chart, in cells F6:Q9. The deviation is calculated in F5:Q5. But for the yearly totals, I only want to compare apples with apples, i.e. months in which sales have been recorded in both years. For that I used cells U6:AF9. The totals in R6:R9 are based on these isnumber() results. This allows you to have the exact deviation between similar months over an user-defined time span.

Ok, time to close. But not before your boss knows the exact portfolio of each product class! Look shortly in data!B6:B45. This is where, using countif(), we have the number of occurrences for each product class. Knowing that product class “A” will be repeated say 3 times, we’ll use this knowledge to look up the third occurrence of “A” and bring up the product next to it. Now take a peak in sheet “Legend”. Knowing we have to lookup for A 1, that’s how I wrote the formula. But also knowing that “A” will be repeated twice for each product (once for 2009, another for 2010) and not wanting to see duplicates in my product list, there’s a very simple solution: just use odd numbers!! This will only bring up every 2nd occurrence of a product. As I said, I like it simple 🙂 I just left the numbers in C5:C15 visible so you don’t have to fish around for them, the rest are simply I the same color as the background. A bit of conditional formatting does the rest.

Of course, before presenting this to any decision maker, you’d hide the rows and columns they’re not supposed to touch and present them with a clean looking table.

Download the Excel Workbook:

Click here to download the workbook with this example. Examine the formulas and chart in “Yr Sls” worksheet to understand how this is weaved together.

[Added by Chandoo]

Thank you Theodor

Thank you so much Theodor for teaching us some valuable techniques on how to compare apples with apples. I am sure our readers will find these ideas very useful.

If you like this post, say thanks to Theodor.

Do you compare & analyze sales data?

I do this all the time. As part of running my small business, every couple of months, I would take up sales data and see if something odd is going on. I make line charts comparing sales of this year with previous year, understanding the overall trend and compare one product with another.

What about you? Do you analyze sales data? What techniques do you use use? Please share using comments.

Learn more from these pages:

If you work a lot with data & do similar work as above, go thru these articles to learn more.

Facebook
Twitter
LinkedIn

Share this tip with your colleagues

Excel and Power BI tips - Chandoo.org Newsletter

Get FREE Excel + Power BI Tips

Simple, fun and useful emails, once per week.

Learn & be awesome.

Welcome to Chandoo.org

Thank you so much for visiting. My aim is to make you awesome in Excel & Power BI. I do this by sharing videos, tips, examples and downloads on this website. There are more than 1,000 pages with all things Excel, Power BI, Dashboards & VBA here. Go ahead and spend few minutes to be AWESOME.

Read my storyFREE Excel tips book

Overall I learned a lot and I thought you did a great job of explaining how to do things. This will definitely elevate my reporting in the future.
Rebekah S
Reporting Analyst
Excel formula list - 100+ examples and howto guide for you

From simple to complex, there is a formula for every occasion. Check out the list now.

Calendars, invoices, trackers and much more. All free, fun and fantastic.

Advanced Pivot Table tricks

Power Query, Data model, DAX, Filters, Slicers, Conditional formats and beautiful charts. It's all here.

Still on fence about Power BI? In this getting started guide, learn what is Power BI, how to get it and how to create your first report from scratch.

13 Responses to “Gantt Box Chart Tutorial & Template – Download and Try today”

  1. Oli says:

    Hi Chandoo

    As one of your students I have followed your detailed example through with great success. However, Excel is acting in an unexpected way and I wonder if you could take a look?
    http://cid-95d070c79aef808e.office.live.com/self.aspx/.Public/Gantt%20Box%20Chart.xlsm
    On my version, I have to type 40239 (Which equates to 2 Mar 2010) to get the chart to display 31 May 2010 (which should be 40329)!!??

    Have I done something wrong or is Excel acting up?

    Thx
    Oli
    PS Your example file in 2007 displays correctly.

  2. Dave says:

    Hi,

    I like this idea a lot, but I agree the name is a little drab.

    As an American I may just be seeing things, but to me the combination of lines and bars on your chart looks like a bunch of cricket bats.

    Maybe you could work that into a catchier name. 🙂

    Cheers!

  3. Bob says:

    Here is some code I use to keep the axis synched.
    It may be useful to some of your readers
    It is based on a comment I saw on Daily Dose of Excel.

    Function SynchGanttAxis(Cname, lower, upper)
    'Sets the X min and X max for Category axis

    Application.Volatile

    On Error Resume Next
    '
    'Top Horizontal Axis
    With ActiveSheet.Shapes(Cname).Chart.Axes(xlCategory, 1)
    .MinimumScale = lower
    .MaximumScale = upper
    End With

    'Bottom Horizontal Axis
    With ActiveSheet.Shapes(Cname).Chart.Axes(xlValue, 2)
    .MinimumScale = lower
    .MaximumScale = upper
    End With

    End Function

    Function SynchVerticalAxis(Cname, lower, upper)
    Application.Volatile
    On Error Resume Next
    ' Excel 2007 only
    'Right hand vertical axis
    With ActiveSheet.Shapes(Cname).Chart.Axes(xlValue, 1)
    .MinimumScale = 0
    .MaximumScale = upper
    End With

    End Function

  4. Chandoo says:

    @Oli.. Can you check your file again.. I see 40329...

    @Dave: Even I saw things.. the bars actually looked like lollipops. How about calling this lollipop chart - now that would be yummy and goes along the tradition of naming charts after eatables (bar, pie, donut...)

    @Bob: Superb stuff... thanks for sharing 🙂

  5. Mike H says:

    Hi Chandoo
    This looks really good and I think it can also be applied to show project phases / milestones.

    Question: Thinking further could this be amended to display a project lifecycle (Idea through to Implementation say 7 phases) on one bar / row? Just imagine 20 projects within a programme all on one chart one bar each showing their respective lifecycle stages i.e. on one page.

    Idea: As the Gantt Box Chart this is quite intensive to set up re formatting etc how about the added extra of once you have completed this to "Save as template" i.e. saves the formatting and layout of the chart as a template so you can apply to future charts. Simple to do and will save the time formatting etc again and again and again.
    Therefore tip: Click on your chart demo and then click on Save As template icon (2007) - edit file name and click on save. Ready to use / apply via Templates in Change Chart Type window.

    Thanks and be very interested if the lifecycle question can be resolved

    Mike

  6. Oli says:

    How embarrassing.

    I was obviously suffering from numerical dyslexia. I was one of those days.

  7. Chandoo says:

    @Mike H: You can easily make this chart to work like a generic project lifecycle plan chart. All you have to do is,

    1. in a separate sheet define the steps of lifecycle and various dates in a table (with 5 columns for each of the projects you have).
    2. now use a control cell to input the project name you want to show in the chart
    3. based on the input, use OFFSET Formulas to get the correct data
    4. Rest is same as the tutorial above

    For more info on the dynamic charting visit http://chandoo.org/wp/tag/dynamic-charts/ and http://chandoo.org/wp?s=OFFSET

  8. Your solution is really smart but in the en Excel isn't meant to do stuff like this. I, as a former PM, always thought is was frustrating that you had to do stuff like this for something simple like a Gantt chart. So I built Tom's Planner. And would like to plug it here. I think it really solves the problem you are trying to solve in the most efficient way. Check out http://www.tomsplanner.com for a free account or play around with the demo.

  9. Lopi says:

    Hi there,
    Chandoo - this is really a very nice and helpfull chart - I adopted it, so I can report a forecast or the delay of a certain task (coming from my role as an auditor for projects).
    One topic I´m currently struggeling with: I do have a project lasting for lets say 12 month. For a management reporting, I want to have kind of snapshot, lets say one month back and 2 month in the future. I tried with the offset formula, but failed. Any idea?
    Thx
    Lopi

  10. [...] Ein viel geliebter Klassiker ist die Erstellung von GANTT-Diagrammen mit Excel. Wir hatten das Thema wiederholt schon hier. Chandoo.org hat sich mal wieder mit einer neuen Variante hervorgetan: Das GANTT-Box-Chart. [...]

  11. David says:

    Hi Chandoo - fantastic xls. One thing I can't figure out how to do is adjust the alignment of the vertical axis. I would like to left align so that I could indent to represent sub tasks. Can that be done? Or is there a better way?

  12. Paul says:

    I've been trying to work out if there's a way to show weekends on the graph. The closest thing I've got is to add them on a secondary axis, but then I haven't been able to keep both axis lined up together! Any ideas?

    Following on from this - is it possible to show things like holidays?

Leave a Reply