指定フォルダ内(サブフォルダ含む)のファイル情報を配列格納「fileNameAllF」の解説

指定フォルダ内のファイル情報を配列格納」では、指定したフォルダ内のファイル情報だけを配列格納しましたが、今回は、サブフォルダを含めてすべてのファイル情報を配列格納するサブルーチンを解説していきます。
こちらの制御では、「fileNameFサブルーチン」を利用することで簡単に取得することが可能です。それでは、制御方法について見ていきましょう。

スポンサー リンク

指定フォルダ内(サブフォルダ含む)のファイル情報を配列格納するサブルーチン


Function fileNameAllF(Optional pathName As String = "myPath") As Variant()

    Dim fileValue() As Variant
    Dim fileCnt As Integer
            
    If sheetName = "mySheet" Then: sheetName = ActiveSheet.Name 'シート名

    strArray = Split(pathName & folderList(pathName), ",")
    
    'FileSystemObjectインスタンスを生成
    Set objSFO = CreateObject("Scripting.FileSystemObject")

    '指定フォルダ内のすべてのファイル数チェック
    For i = LBound(strArray) To UBound(strArray)
    
        fileCnt = fileCnt + objSFO.GetFolder(strArray(i)).Files.Count
        
    Next i
    
    '要素数再セット
    ReDim fileValue(fileCnt - 1, 3)
    
    r = 0

    '指定フォルダ内のすべてのファイル情報を格納
    For i = LBound(strArray) To UBound(strArray)

        With objSFO.GetFolder(strArray(i))
            For Each objFile In .Files
                fileValue(r, 0) = objFile.Name   'ファイル名
                fileValue(r, 1) = .Path & "\" & objFile.Name 'ファイルフルパス名
                fileValue(r, 2) = .Path  'フォルダパス名
                fileValue(r, 3) = .Name    'フォルダ名
                r = r + 1
            Next
        End With
    Next i

    Set objSFO = Nothing
    
    fileNameAllF = fileValue()

End Function

指定フォルダ内のすべてのフォルダを取得するサブルーチン


Function folderList(Optional pathName As String = "myPath", _
                    Optional folderValue As String) As String

    If pathName = "myPath" Then: pathName = ActiveWorkbook.Path 'フォルダパス

    'FileSystemObjectインスタンスを生成
    Set objSFO = CreateObject("Scripting.FileSystemObject")

    '指定フォルダのサブフォルダ内のファイル情報取得
    For Each objSubFolder In objSFO.GetFolder(pathName).subfolders

        folderValue = folderValue & "," & objSubFolder.Path
        
        Call folderList(objSubFolder.Path, folderValue) '再帰呼び出し
    Next

    folderList = Mid(folderValue, 2)
    
End Function

指定フォルダ内(サブフォルダ含む)のファイル情報を配列格納するマクロ

Sub sample()

  Dim pathName As String
  Dim fileData As Variant
    
  pathName = ThisWorkbook.Path & "\file"
    
  fileData = fileNameAllF(pathName)
    
  r = 2
    
  For i = 0 To UBound(fileData)
    
    Cells(r, 1) = fileData(i, 0)
    Cells(r, 2) = fileData(i, 1)
    Cells(r, 3) = fileData(i, 2)
    Cells(r, 4) = fileData(i, 3)
        
    r = r + 1
    
  Next

End Sub

実行結果

フォルダ内(サブフォルダ含む)のファイル名を配列格納

fileNameAllF

こちらの引数は以下の4つです。

引数名データ型内容値の事例初期値省略
pathNameString取得するフォルダパス文字列"C:\Users\vba-ie\Desktop\vba-ie\file\"
fileNameAllF("取得するフォルダパス文字列")

引数は任意項目となります。

「pathName」には、ファイル名を抽出するフォルダのパスを入力します。
初期値は実行ファイルと同じフォルダ内のパスになります。
また、こちらのフォルダ内にあるサブフォルダも対象となります。

folderList

こちらの引数は以下の2つです。

引数名データ型内容値の事例初期値省略
pathNameString取得するフォルダパス文字列"C:\Users\vba-ie\Desktop\vba-ie\file\""myPath"
folderValueStringサブフォルダ情報文字列"C:\Users\vba-ie\Desktop\vba-ie\file,C:\Users\vba-ie\Desktop\vba-ie\file2"
folderList("取得するフォルダパス文字列","サブフォルダ情報文字列")

引数すべてが任意項目となります。

「pathName」には、ファイル名を抽出するフォルダのパスを入力します。
初期値は実行ファイルと同じフォルダ内のパスになります。
「folderValue」には、サブフォルダを含んだフォルダパス文字列が結合された文字列で取得データですので特に指定する必要はありません。
このサブルーチンは、「fileNameAll」「fileNameAllF」サブルーチンに利用されるサブルーチンで指定したフォルダ内のすべてのフォルダ情報を取得しています。

それでは、「fileNameAllFサブルーチン」の制御方法について解説していきます。


If pathName = "myPath" Then: pathName = ActiveWorkbook.Path 'フォルダパス

こちらでは、パス名の初期値を設定しています。
引数を指定している場合は、そちらが利用されます。


strArray = Split(pathName & folderList(pathName), ",")

こちらでは、「folderListサブルーチン」を利用してフォルダ内のすべてのフォルダパスを文字列で返しています。
実際に「foloderListサブルーチン」から返される文字列は以下のようになります。

C:\Users\vbaie\Desktop\vba-ie\file\subfile,
C:\Users\vbaie\Desktop\vba-ie\file\subfile2

こちらは「,(カンマ)」で区切られた文字列ですので、Split関数を利用して分解しています。


Set objSFO = CreateObject("Scripting.FileSystemObject")

フォルダを操作にするには、「FileSystemObjectオブジェクト」を利用します。
こちらではインスタンスを作成しています。


For i = LBound(strArray) To UBound(strArray)
  
 fileCnt = fileCnt + objSFO.GetFolder(strArray(i)).Files.Count
        
Next i
    
'要素数再セット
ReDim fileValue(fileCnt - 1, 3)

こちらでは、サブフォルダを含めたすべてのファイル数をチェックしています。
ファイル数を取得したら、「ReDimステートメント」で配列の要素数を再設定をしています。


r = 0

'指定フォルダ内のすべてのファイル情報を格納
For i = LBound(strArray) To UBound(strArray)

 With objSFO.GetFolder(strArray(i))
  For Each objFile In .Files
   fileValue(r, 0) = objFile.Name   'ファイル名
   fileValue(r, 1) = .Path & "\" & objFile.Name 'ファイルフルパス名
   fileValue(r, 2) = .Path  'フォルダパス名
   fileValue(r, 3) = .Name    'フォルダ名
   r = r + 1
  Next
 End With
Next i

こちらは、「指定フォルダ内(サブフォルダ含む)のファイル情報を配列格納」の制御方法と同様に配列にファイル情報を格納しています。

配列は4次元配列で、それぞれに「ファイル名」「ファイルフルパス名」「フォルダパス名」「フォルダ名」が格納されます。
1階層上の親ディレクトリパスを取得」ではフォルダ名抽出に「InStrRev」関数を利用して抽出しましたが、今回は、「GetFolderオブジェクト」でフォルダ情報を取得していますので、そちらを利用しています。


Set objSFO = Nothing
    
fileNameAllF = fileValue()

最後にオブジェクトを開放し、fileNameAllFに代入して完了です。
ここまでがサブルーチンの解説ですが、実際の使い方について見ていきましょう。


pathName = ThisWorkbook.Path & "\file"
    
fileData = fileNameAllF(pathName)
    
r = 2
    
For i = 0 To UBound(fileData)
    
 Cells(r, 1) = fileData(i, 0)
 Cells(r, 2) = fileData(i, 1)
 Cells(r, 3) = fileData(i, 2)
 Cells(r, 4) = fileData(i, 3)
        
 r = r + 1
    
Next

ざっと説明すると、まず取得するフォルダを指定しpathName変数に代入します。
こちらではフォルダの情報を取得するために「fileNameFサブルーチン」へ引数として渡し、fileData配列変数にファイル情報が格納されます。
後はどういう使い方をするかは自由ですが、こちらでは、A~D列にそれぞれの情報を入力しています。
このように配列データは自由に取り出しができますので、非常に便利ですね。

次の記事: VBAでIE操作に役立つ指定した範囲でランダム(乱数)の整数を取得 >>

Excel VBAでIEを思いのままに操作できるプログラミング術 Excel 2013/2010/2007/2003対応

近田 伸矢, 植木 悠二, 上田 寛

IEのデータ収集&自動操作のプログラミング本はこの1冊だけ!IEの起動やポップアップウィンドウ、表示を制御する基本的なコードはもちろん、テキストボックスやラジオボタン、表、ハイパーリンクなどのHTML部品を制御する方法など、自動操作に欠かせないノウハウを丁寧に解説。

VBAのIE制御についてのQ&A掲示板

↑エクセルVBAのIE(InternetExplorer)操作で分からない事があればこちらの掲示板よりご質問ください^^

ExcelのVBA初心者入門

↑こちらはExcelのVBAをマスターできるよう初心者向けのエクセルVBA入門コンテンツになります^^

VBAのIE制御入門RSS

RSSフィードを登録すると最新記事を受け取ることができます。

VBAIE操作のスカイプレッスン

VBAでIE(InternetExplorer)制御の準備

【ダウンロード】IE操作に便利なツール

こちらでは、これまでに紹介したIE(InternetExplorer)操作で便利な機能をツール化しています。無償でダウンロードできますので、目的に合わせたご利用ください。

IEオブジェクトのメソッド・プロパティ

こちらでは、IE(InternetExplorer)オブジェクトのメソッド・プロパティをまとめています。

IE操作に利用されているVBA関数

こちらでは、エクセルVBAのIE(InternetExplorer)操作で利用されたVBA関数をまとめています。

IE操作に利用されているステートメント

こちらでは、エクセルVBAのIE(InternetExplorer)操作で利用されたステートメントをまとめています。ExcelのVBAで基本的な部分になりますので、しっかり理解しましょう。

IE(InternetExplorer)制御のVBAコード

こちらでは、これまでに作成したIE(InternetExplorer)操作で役立つサブルーチンをまとめています。
全てをコピーする必要はありませんが、目的に合わせたサブルーチンをご利用ください。

ExcelのVBAで作成した役立つVBAコード

こちらでは、IE(InternetExplorer)制御の利用だけでなく、Excel全般で利用できるVBAコードです。エクセルVBAで役に立つものばかりですので、ご利用ください。