# Conditional Formatting to Create 100% Stacked Bar Chart in Excel

A colleague asked me if there was a way to create a dynamic in-cell 100% stacked bar chart in Excel for three product sales.

As usually is the case, there were thousands of rows of data. There is no way she could have used Excel in-built charts as that would have taken her ages to create charts for each set of data points.

This got me thinking, and fortunately, conditional formatting came to the rescue. I was able to quickly create something neat that fits the bill.

##### Creating a 100% Stacked Bar Chart in Excel

Suppose you have sales data for 12 months for three products (P1, P2, and P3). Now you want to create a 100% stacked bar chart in Excel for each month, with each product highlighted in a different color.

Something as shown below: ##### How to create this:

First, you need to calculate the percentage breakup for each product for each month (I was trying to make a 100% stacked chart remember!!).

To do this, first create three helper columns (each for P1, P2, and P3) for all the 12 months. Now simply calculate the % value for each product. I have used the following formula:

`=(C4/SUM(\$C4:\$E4))*100)` Once you have this data in place, let’s dive in right away to make the stacked chart

1. Select 100 columns and set their column width to 0.1.
2. Select these 100 cells in the first data row (K4:DF4) in this case.
3. Go to Home –> Conditional Formatting –> New Rule.
4. In New Formatting Rule Dialogue box, click on ‘Use a formula to determine which cells to format’ option. 5. In the ‘Edit the Rule Description’ put the following formula and set the formatting to Blue (in ‘Fill’ tab)
```=COLUMNS(\$K\$4:K4)<=\$G4
``` 1. Now again select the same set of cells and go to Home – Conditional Formatting – Manage Rules. Click on New Rule tab and again go to ‘Use a formula to determine which cells to format’ option. Now put the formula mentioned below and set the formatting to green color.
`=AND(COLUMNS(\$K\$4:K4)>\$G4,COLUMNS(\$K\$4:K4)<=(\$G4+\$H4))`
1. And finally again repeat the same process and add a third condition with the following formula and set the formatting to orange color.
`=AND(COLUMNS(\$K\$4:K4)>(\$G4+\$H4),COLUMNS(\$K\$4:K4)<=100)`
1. Now click Ok and you would get something as shown below: Hide the helper columns, and you have your dynamic 100% stacked bar chart ready at your service.

Now it’s time to bask in the glory and take out some time to brag about it  If you have enjoyed this tutorial, you might also like these: FREE EXCEL BOOK

## Get 51 Excel Tips Ebook to skyrocket your productivity and get work done faster

### 13 thoughts on “Conditional Formatting to Create 100% Stacked Bar Chart in Excel”

1. It’s an ingenious solution and mr. TrumpExcel is the master of such hacks. The math baffles me, but I managed to get it working on columns just by adding another helper column and including it into the calculations such as the part with +.

While working on it be careful cos the \$K\$4:K4 part seems to change all of a sudden while adding the other conditional formatting rules, so you need to check back at end for any such seemingly random changes that may have occurred.

Next process is to try and figure out how to make this with just 10 columns, cos 100 columns is insane and may slow down a huge worksheet…

• …get it working on 4* columns…

2. Hi, We have this in an excel report but left to right scrolling becomes difficult as there are 100 columns. Is there a different way to do it without 100 columns?

• do with 10 columns. Most can probably do without such a high precision in the chart.

3. Is there a quick way to “select 100 columns”?

4. HI Summit

Can you help me understating the Formulas and the results — I am not getting the logics and not the reaching the solution too.

=COLUMNS(\$K\$4:K4) no of columns =1 which is less than or equal to Cell g4
=AND(COLUMNS(\$K\$4:K4)>\$G4,COLUMNS(\$K\$4:K4)(\$G4+\$H4),COLUMNS(\$K\$4:K4)<=100 ???

5. I need a stacked data bar that is in-cell. Doesn’t need to be 100% Can you help?

6. Can you explain the COLUMNS function a little bit, please? Why do you start at row 9?

7. Really cool idea and implementation!