グラフのX系列の値をRange("T1014:T3014")を指定したいのですが、何故かX系列の値がRange("N1014:N3014")になってしまいます。
cht.SeriesCollection("G-S").XValues = .Range("T1014:T3014")
とそしても実行時エラーで[オブジェクトは、このプロパティまたはメソッドをサポートしていません。]とでてしまいます。
グラフのX系列の値をRange("T1014:T3014")を指定するにはどうしたらいいのでしょうか?
ご教授をお願い致します。
Sub GrapfGS() Dim op As Worksheet, sn As Worksheet, i As Integer, names As String, xname As String Dim cht As ChartObject Dim rng As Range Dim chart1 As Chart Set op = Workbooks("CAB-Grapf.xls").ActiveSheet Application.ScreenUpdating = False 'グラフ作成 Set cht = ActiveSheet.ChartObjects.Add(100, 100, 350, 260) cht.Chart.ChartType = xlXYScatterSmoothNoMarkers cht.Name = "G-S" cht.Top = Range("G4").Top cht.Left = Range("G4").Left cht.Chart.Axes(xlValue).MinimumScaleIsAuto = True cht.Chart.Axes(xlValue).MaximumScaleIsAuto = True cht.Chart.Axes(xlCategory).MaximumScale = 100 cht.Chart.Axes(xlCategory).MinimumScale = 0 cht.Chart.Legend.IncludeInLayout = False cht.Chart.Legend.Position = xlLegendPositionCorner cht.Chart.Legend.Format.Fill.ForeColor.ObjectThemeColor = msoThemeColorBackground1 cht.Chart.Axes(xlValue).TickLabels.NumberFormatLocal = General cht.Chart.HasTitle = True cht.Chart.ChartTitle.Text = "G-S" 'データ取得ループ For i = 1 To Worksheets(1).Range("H1").Value If i > 10 Then MsgBox "データーがそんなにないよ(V)o¥o(V)" Exit For End If With Worksheets(2 + i) 'データ範囲の取得 If i = 1 Then '初回は見出し列も取得 Set rng = .Range("T1014:T3014, N1014:N3014") 'グラフにデータソースを設定 cht.Chart.SetSourceData Source:=rng cht.SeriesCollection("G-S").XValues = .Range("T1014:T3014") Else '2回目以降はデータ系列を追加 Set rng = .Range("N1014:N3014") cht.Chart.SeriesCollection.Add rng End If End With 'グラフの名前をDATAシートから取得>Grapfシートを選択して貼り付け。 names = Worksheets(1).Range("B" & i + 1).Value Worksheets(2).Select cht.Chart.SeriesCollection(i).Name = names Next End Sub
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/01/30 00:53
2017/01/30 08:53
2017/01/30 09:14