The following chart illustrates a nice configuration for horizontal bar chart labels. These labels take the place of category labels and value data labels, and they are nicely aligned above the corresponding bars.
data:image/s3,"s3://crabby-images/e51c7/e51c7d920f24477207b1efd6854d4a9ca4be5a02" alt="Desired Bar Chart Data Label Configuration"
These labels are not hard to do in Excel, and I’ll show you how.
Start with the following data. Note that the data is repeated in duplicate columns, labeled Blank and Data. Ultimately the Blank series will have hidden bars and data labels. Create a bar chart, shown next to the data.
data:image/s3,"s3://crabby-images/d03a5/d03a56175f6a6c45b7a5d753501c28d0176133d6" alt="Chart Data and Initial Bar Chart"
First, format the vertical axis. Select the axis and press Ctrl+1. Under the Axis Option icon, check the box for Categories in Reverse Order; under Labels, select No Labels. Under the paint can (Fill & Line) icon, select No Line.
data:image/s3,"s3://crabby-images/35c11/35c11d98c71dbdae3a7d47f2c8ee2a0f152cfda8" alt="Format Vertical Axis (Categories in Reverse Order, No Line)"
Now hide some unneeded chart elements. Select the horizontal axis, press Ctrl+1. Under Axis Options, for Labels select No Labels. Select and delete the horizontal gridlines, then select and delete the legend.
data:image/s3,"s3://crabby-images/3b7cf/3b7cf7c45aa96ff83120fff6bb9fbe94e3737075" alt="Hide Unneeded Elements (Horizontal Axis Labels, Gridlines, Legend)"
Next, adjust the spacing of the bars. Select either series and press Ctrl+1. Under Series Options, enter a Gap Width of 100% and a Series Overlap of -20%. You may later adjust these settings to fine-tune your label configuration.
data:image/s3,"s3://crabby-images/3b66e/3b66e1f5a3bdfe34a446d04690039e09005d768f" alt="Adjust bar gap width and overlap"
Apply series fill colors. For the Data series, apply the desired fill color (I’ve used a medium gray). For the Blank series, select No Fill.
data:image/s3,"s3://crabby-images/020ba/020badc8b1869eefc0aa0fe9ab56dc0c8b6a9e2b" alt="Apply series fill colors. Data: medium gray; Blank: No Fill."
Now apply and format your data labels. Select the blank series (you should be able to click on it even if it’s blank, but if not select the visible series and press Ctrl and the down arrow key). Click the Chart Elements skittle (the plus icon next to the chart), select Data Labels > More Options.
Under Label Options, check Value and Category Name. Enter the pipe character | for your separator, and choose the Inside Base position. Enter an appropriate number format for your data labels. To show the values in millions of dollars, I used this format:
$0.0,, \M
Under Text Options > Textbox, uncheck Wrap Text in Shape, and enter zero for the Left Margin.
data:image/s3,"s3://crabby-images/a7cca/a7ccaaba1dca818909adb023ead957d68ed72778" alt="Apply Data Labels to Blank Series: Inside Base, Category and Value, define number format, no line wrap, zero left margin"
Finally enter your desired chart title, and drag the chart title to the left of the chart (hold Shift while dragging so the title moves horizontally).
data:image/s3,"s3://crabby-images/e51c7/e51c7d920f24477207b1efd6854d4a9ca4be5a02" alt="Final Label Alignment"
Now your bar chart has nicely arranged labels, and it only took a minute or two.
A VBA Procedure and Add-In to Add Nice Bar Chart Data Labels
Bill commented that it would be informative to have a VBA procedure to label a bar chart using this protocol. Great idea, so I wrote a follow-up post to describe the code and present an add-in that can be downloaded. See Nice Bar Chart Data Labels Using VBA.