OfficeType

VBA~グラフの中に値を表示しよう~Excel

VBAでグラフの中に値を表示する方法を解説します。

グラフの中に値を表示したい場合、ChartオブジェクトのSeries.HasDataLabelsプロパティで設定できます。SeriesCollectionの()内にはインデックス番号か名前を指定します。インデックス番号は凡例が横方向に並んでいる場合は左から1,2,3・・・となり、凡例が縦方向に並んでいる場合は上から1,2,3・・・となります。

既にグラフがある場合

下の画像において下のコードを実行するとグラフの中に値が表示されます。

image-01

Sub test1()

With ActiveSheet.ChartObjects(1).Chart

.SeriesCollection(1).HasDataLabels = True
.SeriesCollection(2).HasDataLabels = True
.SeriesCollection(3).HasDataLabels = True

End With

End Sub

image-02

グラフのインデックス番号はグラフの作成順に割り振られます。今回はグラフが1つしかないのでグラフのインデックス番号は1となりChartObjects(1)となります。

系列のデータラベルの位置を設定

系列のデータラベルの位置を設定したい場合DataLabels.Positionプロパティで設定できます。xlLabelPositionCenter,xlLabelPositionInsideBase,xlLabelPositionInsideEnd,xlLabelPositionOutsideEndがそれぞれ中央揃え、内側、内側下、外側に対応しています。

下の画像において下のコードを実行すると商品Aのデータラベルが中央揃えになります。

image-03

Sub test2()

With ActiveSheet.ChartObjects(1).Chart

.SeriesCollection(1).HasDataLabels = True
.SeriesCollection(1).DataLabels.Position = xlLabelPositionCenter

End With

End Sub

image-04

グラフ作成時にグラフの中に値を表示

下のコードを実行するとグラフ作成時にグラフの中に値を表示します。

Sub test3()

With ActiveSheet.Shapes.AddChart.Chart

.ChartType = xlColumnClustered
.SetSourceData Range(Range("A3"), Range("D10"))

.SeriesCollection(1).HasDataLabels = True
.SeriesCollection(2).HasDataLabels = True
.SeriesCollection(3).HasDataLabels = True

End With

End Sub

コードの説明

WithからEnd Withまでがグラフの作成、設定です。

ActiveSheet.Shapes.AddChart.Chart

グラフエリアを追加しています。

image-05

.ChartType = xlColumnClustered

グラフの種類を設定しています。xlColumnClusteredは棒グラフの集合縦棒になります。

image-06

.SetSourceData Range(Range("A3"), Range("D10"))

グラフのデータ範囲を設定しています。

.SeriesCollection(1).HasDataLabels = True

商品Aの系列にデータラベルを設定しています。

image-07

.SeriesCollection(2).HasDataLabels = True

商品Bの系列にデータラベルを設定しています。

image-08

.SeriesCollection(3).HasDataLabels = True

商品Cの系列にデータラベルを設定しています。

image-09