【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.
シート名や列番号が正しいか確認してください。