📘 Excel逆引き事典

【VBA】非表示シートをバックグラウンドで配列に格納する方法

手作業で大量のデータを管理するのは大変です。特に非表示のシートを扱う場合、労力と時間がかかります。この記事では、VBAを使用して非表示のワークシートをバックグラウンドで高速化し配列に格納する方法を紹介します。

サンプルコード

VBA
Option Explicit
Sub StoreHiddenSheetsToArray()
    Dim ws As Worksheet, arr() As Variant
    Dim i As Integer, j As Integer
    ReDim arr(1 To ThisWorkbook.Sheets.Count)
    
    Application.ScreenUpdating = False
    For Each ws In ThisWorkbook.Worksheets
        If ws.Visible = xlSheetHidden Then
            j = j + 1
            ReDim Preserve arr(1 To j)
            arr(j) = ws.Name
        End If
    Next ws
    
    ' 配列を表示するためのサンプルコード(実際には配列を使用した処理を行う)
    For i = LBound(arr) To UBound(arr)
        Debug.Print arr(i)
    Next i
    
    Application.ScreenUpdating = True
End Sub

よくある質問

Q 元に戻せますか?

A.
VBAの実行結果は「元に戻す」が効きません。必ずバックアップを取ってから実行してください。

Q エラーが出たら?

A.
シート名や列番号が正しいか確認してください。