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.

26 Responses to “Get busy this weekend, with OR XOR AND [Excel Homework]”

  1. Stef@n says:

    first solution for AND
    The two numbers are in A1 and B1
    = SUBSTITUTE (SUBSTITUTE (A1+B1*9*9, 9, 1), 8, 0)
    regards
    Stef@n

  2. Stef@n says:

    next solution for OR
    =1*SUBSTITUTE (A1+A2;2;1)

    regards
    Stef@n

  3. Stef@n says:

    last solution for XOR
    =1*SUBSTITUTE (A1+A2;2;0)

    regards
    Stef@n

  4. Irvine says:

    Or you could make use of the VBA logical operators!

    Define the following as custom functions
    Public Function BITXOR(x As Long, y As Long)
    BITXOR = x Xor y
    End Function

    Public Function BITAND(x As Long, y As Long)
    BITAND = x And y
    End Function

    Public Function BITOR(x As Long, y As Long)
    BITOR = x Or y
    End Function

    and then use them such:
    A B =BITOR(A,B) =BITAND(A,B) =BITXOR(A,B)
    0101 0100 0101 0100 0001

  5. Stef@n says:

    an another solution for AND
    =1*SUBSTITUTE (SUBSTITUTE (A1+A2;1;0);2;1)

    note:
    the binary numbers are in A1 and A2 !
    regards
    Stef@n

  6. Shair says:

    I was obviously playing hooky at the beach during the bit-wise math lesson – you lost me at “Understanding bit-wise operations” 🙂

  7. Anup Agarwal says:

    After looking at the above solutions, I find my solution silly, but still:

    For the following formulae,
    Row 1: headers,
    Row 2: OR
    Row 3: AND
    Row 4: XOR

    Column 1: Input 1
    Column 2: Input 2
    Column 3: Result

    OR
    {=SUM(IF(MID(A2,ROW(OFFSET($A$1,0,0,LEN(A2),1)),1)+MID(B2,ROW(OFFSET($A$1,0,0,LEN(B2),1)),1)>0,1,0)*10^(LEN(A2)-ROW(OFFSET($A$1,0,0,LEN(B2),1))))}

    AND
    {=SUM(IF(MID(A3,ROW(OFFSET($A$1,0,0,LEN(A3),1)),1)+MID(B3,ROW(OFFSET($A$1,0,0,LEN(B3),1)),1)=2,1,0)*10^(LEN(A3)-ROW(OFFSET($A$1,0,0,LEN(B3),1))))}

    XOR
    {=SUM(IF(MID(A4,ROW(OFFSET($A$1,0,0,LEN(A4),1)),1)+MID(B4,ROW(OFFSET($A$1,0,0,LEN(B4),1)),1)=1,1,0)*10^(LEN(A4)-ROW(OFFSET($A$1,0,0,LEN(B4),1))))}

  8. Hui... says:

    @Anup
    Please don't consider your solution silly
    Firstly, You are the 3rd person to submit an answer
    Secondly, The best formula/function is the one that you know and understand.

  9. Michael Azer says:

    I think I have a very tedious solution, which people won't have the patience to do except in small numbers.

    I used the same problem setup as "Anup Agarwal"

    AND =IF(AND(MID(B2,1,1)="1",MID(C2,1,1)="1"),1,0)&IF(AND(MID(B2,2,1)="1",MID(C2,2,1)="1"),1,0)&IF(AND(MID(B2,3,1)="1",MID(C2,3,1)="1"),1,0)&IF(AND(MID(B2,4,1)="1",MID(C2,4,1)="1"),1,0)

    OR =IF(OR(MID(B3,1,1)="1",MID(C3,1,1)="1"),1,0)&IF(OR(MID(B3,2,1)="1",MID(C3,2,1)="1"),1,0)&IF(OR(MID(B3,3,1)="1",MID(C3,3,1)="1"),1,0)&IF(OR(MID(B3,4,1)="1",MID(C3,4,1)="1"),1,0)

    =IF(OR(AND(MID(B4,1,1)="1",MID(C4,1,1)="0"),AND(MID(B4,1,1)="0",MID(C4,1,1)="1")),1,0)&IF(OR(AND(MID(B4,2,1)="1",MID(C4,2,1)="0"),AND(MID(B4,2,1)="0",MID(C4,2,1)="1")),1,0)&IF(OR(AND(MID(B4,3,1)="1",MID(C4,3,1)="0"),AND(MID(B4,3,1)="0",MID(C4,3,1)="1")),1,0)&IF(OR(AND(MID(B4,4,1)="1",MID(C4,4,1)="0"),AND(MID(B4,4,1)="0",MID(C4,4,1)="1")),1,0)

  10. Michael Azer says:

    Sorry my last post was totally messed up

    AND
    =IF(AND(MID(B2,1,1)="1",MID(C2,1,1)="1"),1,0)&IF(AND(MID(B2,2,1)="1",MID(C2,2,1)="1"),1,0)&IF(AND(MID(B2,3,1)="1",MID(C2,3,1)="1"),1,0)&IF(AND(MID(B2,4,1)="1",MID(C2,4,1)="1"),1,0)
    OR
    =IF(OR(MID(B3,1,1)="1",MID(C3,1,1)="1"),1,0)&IF(OR(MID(B3,2,1)="1",MID(C3,2,1)="1"),1,0)&IF(OR(MID(B3,3,1)="1",MID(C3,3,1)="1"),1,0)&IF(OR(MID(B3,4,1)="1",MID(C3,4,1)="1"),1,0)
    XOR
    =IF(OR(AND(MID(B4,1,1)="1",MID(C4,1,1)="0"),AND(MID(B4,1,1)="0",MID(C4,1,1)="1")),1,0)&IF(OR(AND(MID(B4,2,1)="1",MID(C4,2,1)="0"),AND(MID(B4,2,1)="0",MID(C4,2,1)="1")),1,0)&IF(OR(AND(MID(B4,3,1)="1",MID(C4,3,1)="0"),AND(MID(B4,3,1)="0",MID(C4,3,1)="1")),1,0)&IF(OR(AND(MID(B4,4,1)="1",MID(C4,4,1)="0"),AND(MID(B4,4,1)="0",MID(C4,4,1)="1")),1,0)

  11. Stephen says:

    @stefan,
    I just couldn't get your solutions to work.
    01010101010 + 01010101110 = 02020210120
    what am i doing wrong?

  12. Stephen says:

    @anup
    ...I got yours to work!

  13. Rich says:

    @Stephen - I get the same, but Stef@an's second solution for AND does work (at least for the test cases I used)

  14. Stef@n says:

    @ Stephen / Rich
    yes , you are right ! - only this works:

    OR
    =1*SUBSTITUTE (A1+A2;2;1)
    XOR
    =1*SUBSTITUTE (A1+A2;2;0)
    AND
    =1*SUBSTITUTE (SUBSTITUTE (A1+A2;1;0);2;1)

  15. Michael Azer says:

    @Stef@n - You're answer is really smart, I never knew about the substitute function before. Great Work!

  16. Stef@n says:

    Thx Michael 🙂
    yes - it is simply easy 😉
    if you add 1 and 1 - excel calculate 2
    and then you have to substitute the 2 - new = 0 respectively 1

  17. Rob says:

    Here is a good resource for people wanting to learn binary and hexadecimal.
    http://justwebware.com/bitwise/bitwise.html

  18. Kyle McGhee says:

    Three that weren't asked for:
    NOT
    =SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(A1+A2,0,3),1,0),3,1)

    EQV
    =SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(A1+A2,0,3),2,3),1,0),3,1)

    IMP
    =SUBSTITUTE(SUBSTITUTE(A1+SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(A2,0,3),1,0),3,1),0,1),2,0)

    (was using Daniel Ferry's bitwise file to verify against)

  19. Q says:

    @ Kyle

    Not only takes one parameter and inverts 0 -1 and 1-0

    Took out the +A2
    =SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(A1,0,3),1,0),3,1)

  20. Great solutions!

    I'll add two:

    NAND =1*SUBSTITUTE (A1+A2,2,0)

    NOR=1*SUBSTITUTE(SUBSTITUTE (SUBSTITUTE(A1+A2,0,2),1,0),2,1)

  21. John Fuller says:

    This will work for binary numbers of any size (although the text format mask will have to have as many zeroes as there are digits in the longest addend)

    Assume binary #s are in C35 & C36, then add and format as text in C37:
    =TEXT(C36+C35,"000000000000")
    -sum- = 101112211112

    AND - SUBSTITUTE 0s for 1s in -sum-, then sub 1s for 2s
    =SUBSTITUTE(SUBSTITUTE(C37,"1","0"),"2","1")

    OR - sub 1s for 2s in -sum-
    =SUBSTITUTE(C37,"2","1")

    XOR - sub 0s for 2s in -sum-
    =SUBSTITUTE(C37,"2","0")

  22. Shane says:

    Just wandered by:

    AND:

    =SUBSTITUTE(A1+A2,1,0)/2

  23. Ronald Vonk says:

    Hi Chandoo,

    I am not (yet) really into bitwise calculation, but I am looking for a way to speed up my vba calculation with very big numbers. Would is ben convenient to use bitwise notation for this?

    Best regards,

    Ronald (the Netherlands)
    p.s. love your country!

Leave a Reply