忍者ブログ
バイオインフォマティックス技術者試験、情報処理試験など、IT系の試験を基礎から勉強します。また、Javaなどプログラミングを勉強します。

【VBA】構造体の配列でデータを一括管理!複数の関連データを効率よくループ処理する方法

「ユーザー定義型(構造体)」の真価は、配列と組み合わせたときに発揮されます。例えば、新旧の対応表や名簿データなど、同じ構造を持つ大量のデータをメモリ上で高速に、かつ整理された状態で扱うことができます。

1. 実践サンプル:新旧対応表(変換テーブル)の管理

複数の要素(old, new)を持つ構造体を配列にすることで、関連するデータをセットにしたままループ処理が可能になります。

' --- 標準モジュールの先頭で宣言 ---
Option Explicit

' 構造体の定義
Public Type TransforTable
    old As Integer
    newVal As Integer ' ※newは予約語のためnewValとしています
End Type

Sub Macro2()
    ' 構造体の配列を宣言(要素数2)
    Dim TransforTables(1 To 2) As TransforTable

    ' 1番目のデータセット
    TransforTables(1).old = 1
    TransforTables(1).newVal = 10

    ' 2番目のデータセット
    TransforTables(2).old = 2
    TransforTables(2).newVal = 20

    Dim i As Integer
    For i = 1 To 2
        Debug.Print TransforTables(i).old
        Debug.Print TransforTables(i).newVal
    Next i
End Sub

2. アルゴリズムのポイント

重要:ループ内ではカウンタ変数「i」を正しく使う

配列をループで回す際は、TransforTables(i).newVal のように添字に変数 i を指定します。ここを固定値(1など)にしてしまうと、せっかくのループでも同じデータしか参照できないため注意が必要です。

3. 実行結果

各要素の old と newVal が順番に出力されます。

1
10
2
20

4. なぜ「構造体の配列」が最強なのか?

1. ここがメリット!: oldValues() と newValues() という2つの別々な配列を作るよりも、構造体の配列1つにする方が「データの整合性」が保てます。1行分のデータが常にセットで動くため、並べ替えや引数の受け渡しが非常に「いけいけ」でスムーズになります。
2. エンジニアの視点: これはデータベースのレコードをメモリ上にロードする際の基本形です。JavaやC#での「オブジェクトのリスト」に近い感覚でVBAを扱えるようになります。大規模な変換ロジックを組む際は、まずこの構造を検討しましょう。
3. デバッグのコツ: ローカルウィンドウを表示すると、配列の中にある構造体の各要素がツリー形式で表示されます。変数の中身が一目瞭然になるため、開発効率が劇的に向上します。


5. まとめ

構造体と配列の組み合わせは、VBAにおける「データ管理の決定版」です。バラバラだった変数を構造化し、配列で一括制御することで、コードの可読性と保守性は格段に高まります。複雑なデータ加工が必要な時こそ、この手法を思い出してください。




PR