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

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

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

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

Q&A

解決済

2回答

367閲覧

VBAの繰り返し処理の方法

kaiserdoragon

総合スコア21

VBA

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

0グッド

0クリップ

投稿2020/03/24 06:12

お世話になります。

VBAのFOR~NEXT文の処理で不明点があり質問させていただきます。

こちらのサイトにある
https://www.sejuku.net/blog/29274

VBA

1Sub macro1() 2 Dim arr_int(2) As Integer 3 Dim arr_str(2) As String 4 5 'Eraseで初期化 6 Erase arr_int 7 Erase arr_str 8 9 '要素の取得と表示 10 Dim i As Integer, str As String 11 str = "arr_int" 12 For i = 0 To 2 13 str = str & ", " & arr_int(i) 14 Next i 15 str = str & vbCrLf & "arr_str" 16 For i = 0 To 2 17 str = str & ", " & arr_str(i) 18 Next i 19 20 MsgBox str, vbInformation 21End Sub

なのですが、結果的には下記画像のようになるのですが、なぜこの結果になるのかわかりません。

イメージ説明

特にarr_int,0,0,0の0,0,0の部分やarr_str,,,の,,,の部分ですがarr_intやarr_strはなぜ繰り返されないのかが一番わかりません。

ご教授お願いします。

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

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

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

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

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

otn

2020/03/24 07:13

どういう結果になると思ったのでしょうか?
kaiserdoragon

2020/03/24 07:33

お世話になります! 当初は arr_int,0 arr_int,0,0 arr_int,0,0,0 が出力されると思っており、なぜ数字や空白だけが増えるのだと思っていました。 文法や初期化の概念が理解できていなかったのではなくて、For文の変化が頭の中で処理がしっかりできていないことが原因でした。
guest

回答2

0

ベストアンサー

どの辺が分からないのか不明なので、とりあえず各コードにコメントを付けておきました。

vba

1Sub macro1() 2 Dim arr_int(2) As Integer '3つの要素を持つ数値の配列(インデックスは0から始まる) 3 Dim arr_str(2) As String '3つの要素を持つ文字列の配列(インデックスは0から始まる) 4 5 'Eraseで初期化 6 Erase arr_int '数値型の初期値は0なので、{0,0,0}の配列 7 Erase arr_str '文字列型の初期値は""(中身が空の文字列)なので、{"","",""}の配列 8 9 '要素の取得と表示 10 Dim i As Integer, str As String 11 str = "arr_int" 'str変数に"arr_int"を代入 12 For i = 0 To 2 13 str = str & ", " & arr_int(i) 'str変数に数値配列の要素の値(0)をカンマ区切りで追加 14 Next i 15 str = str & vbCrLf & "arr_str" ''str変数に改行(vbCrLf)と"arr_str"を追加 16 For i = 0 To 2 17 str = str & ", " & arr_str(i) 'str変数に文字列配列の要素の値("")をカンマ区切りで追加 18 Next i 19 20 MsgBox str, vbInformation 'str変数の内容をメッセージボックスに表示 21End Sub

上記のコメントをみても分からない部分があれば、どこがどのように分からないのか、具体的に質問してください。

投稿2020/03/24 06:38

hatena19

総合スコア33699

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

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

kaiserdoragon

2020/03/24 07:27

ご回答ありがとうございます! 解決することができました! わからなかった原因はFor分の値の変化をしっかりと追えておりませんでした。 アナログですが、変化を紙に書いたところしっかり理解できました。 丁寧にコードにコメントありがとうございます。
guest

0

VBA

1 Erase arr_int 2 Erase arr_str

Integerの配列arr_intを初期化するので要素の値は0になります。
Stringの配列arr_strを初期化するので要素の値は空文字になります。

VBA

1str = str & ", " & arr_int(i)

変数strにカンマ+空白と配列の要素を結合して、str自身に代入しています。
ループ前のstr は arr_int
ループ1回目   arr_int, 0
ループ2回目   arr_int, 0, 0
ループ3回目   arr_int, 0, 0, 0

arr_strのループも同じ仕組みです。

投稿2020/03/24 06:28

DreamTheater

総合スコア1095

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

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

kaiserdoragon

2020/03/24 07:29

ご回答ありがとうございます! 解決することができました! わからなかった原因はFor分の値の変化をしっかりと追えておりませんでした。 紙にFor分の変化を書きだしたところ解答いただいた内容がしっかり理解できました! ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問