4.グラフ作成資料

グラフは自動記録でマクロを作成できるので、とくにテクニック的なものはなく誰でも簡単に グラフプロシージャを組むことが出来ます。
しかし、VBA高級者でも自分の期待した通りのグラフにするには、何回も自動記録をし最初に 記録したロシージャの修正が必要となります。グラフに関するプロパティやメソッドの引数の資料 があれば短時間でマクロを作成できるので、その資料を作成しました。

以下の「乖離率」作成マクロを例に説明します。

'シート名
    shname = ActiveSheet.Name  'シート名取得
    yasune = Cells(1, 11)    ’セルCells(1, 11)の安値を変数(yasune)へ代入 

'グラフデータ指定                         '[1]
Set myrange = Union(Range(Cells(3, 1), Cells(60, 1)), _
Range(Cells(3, 6), Cells(60, 6)), _
Range(Cells(3, 9), Cells(60, 10)))

'グラフ表示場所
ActiveSheet.ChartObjects.Add(5, 18, 550, 250).Select               '[2]
    
    
    ActiveChart.ChartType = xlLineMarkers                          '[3]
    
    ActiveChart.SetSourceData Source:=myrange, PlotBy:=xlColumns   '[4]
        
    ActiveChart.Location Where:=xlLocationAsObject, Name:=shname   '[5]
    
'軸→項目(データあり表示)                                        '[6]
ActiveChart.Axes(xlCategory, xlPrimary).CategoryType = xlCategoryScale

'第2軸の設定                                                      '[7]
ActiveChart.PlotArea.Select
    ActiveChart.SeriesCollection(3).Select
    ActiveChart.SeriesCollection(3).AxisGroup = 2
    
'左目盛の文字調整                                                   '[8]
With ActiveChart.Axes(xlValue)
     .TickLabels.Font.Size = 8
         If .MaximumScale < 1001 Then
            .MinimumScale = Int(Int(yasune * 0.8) / 10) * 10
        Else
            .MinimumScale = Int(Int(yasune * 0.8) / 100) * 100
        End If
End With

'右目盛の文字調整                                                    '[9]
With ActiveChart.Axes(xlValue, xlSecondary)
     .TickLabels.Font.Size = 8
End With


'下目盛の文字調整                                                  '[10]
With ActiveChart.Axes(xlCategory).TickLabels
        .Font.Size = 8
        .NumberFormatLocal = "yy/mm/dd"
        .Orientation = xlDownward
End With

'日付を逆にする                                                    '[10-1]
    With ActiveChart.Axes(xlCategory)
        .CrossesAt = 1
        .TickLabelSpacing = 2
        .TickMarkSpacing = 1
        .AxisBetweenCategories = True
        .ReversePlotOrder = True
    End With

'プロットアリアの色                        '[11]
 ActiveChart.PlotArea.Interior.ColorIndex = 2
  
'ボン例位置
 ActiveChart.Legend.Position = xlBottom                             '[12]
 
'グラフ線の装飾                                                     '[13]
    With ActiveChart.SeriesCollection(1)
        .Border.ColorIndex = 1
        .Border.Weight = xlThick
        .Border.LineStyle = xlContinuous
        .MarkerStyle = xlNone
    End With


4-1グラフデータ指定

Set myrange = Union(Range(Cells(3, 1), Cells(60, 1)), _
Range(Cells(3, 6), Cells(60, 6)), _
Range(Cells(3, 9), Cells(60, 10)))
[1] 下図のAFIJ列を選択した例。
[2] Unionメソッドでセル範囲を集合させることができるので、Range()を追加・削除で修正できます。


[3] 上記は列が離れている場合ですが、連続したセル(例:HIJ列)指定は下記でよい

Set rangch =Range(Cells(3, 8), Cells(60, 10)))


4-2 新しいチャートを作成

ActiveSheet.ChartObjects.Add(5, 18, 550, 250).Select
[1] ChartObjects.Add メソッドで、新しいチャートを作成
[2] 作成する場所の指定方法(5, 18, 550, 250)は下図参照



4-3 グラフの種類を指定

ActiveChart.ChartType = xlLineMarkers 
下図は通常のグラフ作成で表示されるウィダードですが、VBAチャート名は下記の通りです

[1]ActiveChart.ChartType = xlColumnClustered '縦棒

[2]ActiveChart.ChartType = xlBarClustered   ’横棒

[3]ActiveChart.ChartType = xlLineMarkers   ’折れ線

[4]ActiveChart.ChartType = xlPie       '円

[5]ActiveChart.ChartType = xlXYScatter    ’散布図

[6]ActiveChart.ChartType = xlAreaStacked   ’面

[7]ActiveChart.ChartType = xlDoughnut     ’ドーナツ

[8]ActiveChart.ChartType = xlRadarMarkers   ’レーダー

[9]ActiveChart.ChartType = xlSurface     ’等高線

[10]ActiveChart.ChartType = xlBubble     ’バルブ

[11]ActiveChart.ChartType = xlStockVOHLC   ’株価

[12]ActiveChart.ChartType = xlCylinderColClustered ’円柱

[13]ActiveChart.ChartType = xlConeColClustered   ’円錐

[14]ActiveChart.ChartType = xlPyramidColClustered  ’ピラミット






4-4グラフのソースデータ範囲指定

ActiveChart.SetSourceData Source:=myrange, PlotBy:=xlColumns
[1] Source:=myrange → [1]のSetステートメントで指定した(myrange)を参照
[2] PlotBy:=xlColumns → グラフのデータ系列が、列か行かを指定
・xlColumns(列を使用)、xlRows(行を使用)
 


4-5グラフを新しい位置に移動

ActiveChart.Location Where:=xlLocationAsObject, Name:=shname
[1] Where:=xlLocationAsObject の場合は、 Name:=でグラフを貼るシート名指定
   (本例の変数(shname)には、事前に貼るシート名を入れてあります)
[2] Where:=xlLocationAsNewSheet の場合は、 Name:=で新しいシート名指定


4-6項目軸の種類を設定

ActiveChart.Axes(xlCategory, xlPrimary).CategoryType = xlCategoryScale
[1] 軸の種類は自動記録では「グラフオプション」で指定できます(下図参照)


[2] 自動→ ActiveChart.Axes(xlCategory, xlPrimary).CategoryType = xlAutomatic
[3] 時系列→ActiveChart.Axes(xlCategory, xlPrimary).CategoryType = xlTimeScale
本例のように軸が日付形式の場合、「自動」または「時系列」を指定の場合は、下図のように グラフデータに無い土曜日・日曜日も勝手に項目を作りグラフ化されます。 (全然便利と思わないがExcel内蔵の基本機能)


[4]項目→ActiveChart.Axes(xlCategory, xlPrimary).CategoryType = xlCategoryScale
項目を指定した場合は、下図のように実際にあるデータのみがグラフになります




4-7 第2軸の設定

ActiveChart.PlotArea.Select
    ActiveChart.SeriesCollection(3).Select
    ActiveChart.SeriesCollection(3).AxisGroup = 2
[1] 第2軸を設定したい系列を選択し(本例では系列3の乖離率)ダブルクリックで、 下図の書式設定のダイアログが表示されるので、第2軸指定で自動記録できます





【戻る】