質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

1回答

1353閲覧

VBAでグラフ系列名の取得について

ItoM

総合スコア8

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2018/03/02 15:52

VBA初心者です。
自動でグラフを作成するVBAを作成しています。
B2,C2,D2....と系列の値のある範囲のみ名前を取得したいのですが
取得した値が系列にうまく反映できません。

イメージ説明

##データの範囲は以下の構文でB3を起点に値のある範囲を取得しています。
y_offset = 3
x_offset = 2

y_temp = y_offset continue_flag = True Do While continue_flag = True If Len(Cells(y_temp, x_offset).Value) > 0 Then y_temp = y_temp + 1 Else continue_flag = False End If Loop x_temp = x_offset continue_flag = True Do While continue_flag = True If Len(Cells(y_offset, x_temp).Value) > 0 Then x_temp = x_temp + 1 Else continue_flag = False End If Loop y_end = y_temp - 1 x_end = x_temp - 1 ※ここまではうまく取れています

系列の取得は以下構文で作成しています

' 系列の名前 For n = x_offset To x_end - 1 series_names = Array(ActiveSheet.Cells(y_offset - 1, n).Value) Next n ' 系列名をセット For i = 0 To x_end - x_offset .SeriesCollection(i + 1).Name = series_names(i) Next i

series_names(i)をデバッグで見ると
series_names(i) = <インデックスが有効範囲にありません。>と表示されてしまい系列が取得できていません。
Arrayに入れる構文が悪いのか、系列へ反映させるの構文が間違ってるのかわかりません。

わかりづらい文章で申し訳ないのですが、ご教示いただけないでしょうか
イメージ説明

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

すみません。
自己解決しました。

#変更点
arrayをforではなく以下の形へ修正

series_names = Array(ActiveSheet.Range("B2").Value, _ ActiveSheet.Range("C2").Value, _ ActiveSheet.Range("D2").Value, _ ActiveSheet.Range("E2").Value, _ ActiveSheet.Range("F2").Value)

系列名を以下の形で取得
For i = 1 To x_end - 1
.SeriesCollection(i).Name = series_names(i - 1)
Next i

投稿2018/03/02 16:03

ItoM

総合スコア8

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問