VBA 递归枚举文件夹和文件
例子
早期绑定(参考MicrosoftScriptingRuntime)
Sub EnumerateFilesAndFolders( _
FolderPath As String, _
Optional MaxDepth As Long = -1, _
Optional CurrentDepth As Long = 0, _
Optional Indentation As Long = 2)
Dim FSO As Scripting.FileSystemObject
Set FSO = New Scripting.FileSystemObject
'Check the folder exists
If FSO.FolderExists(FolderPath) Then
Dim fldr As Scripting.Folder
Set fldr = FSO.GetFolder(FolderPath)
'Output the starting directory path
If CurrentDepth = 0 Then
Debug.Printfldr.Path
End If
'Enumerate the subfolders
Dim subFldr As Scripting.Folder
For Each subFldr In fldr.SubFolders
Debug.PrintSpace$((CurrentDepth + 1) * Indentation) & subFldr.Name
If CurrentDepth < MaxDepth Or MaxDepth = -1 Then
'Recursively call EnumerateFilesAndFolders
EnumerateFilesAndFolders subFldr.Path, MaxDepth, CurrentDepth + 1, Indentation
End If
Next subFldr
'Enumerate the files
Dim fil As Scripting.File
For Each fil In fldr.Files
Debug.PrintSpace$((CurrentDepth + 1) * Indentation) & fil.Name
Next fil
End If
End Sub使用以下参数调用时的输出:EnumerateFilesAndFolders"C:\Test"
C:\Test
Documents
Personal
Budget.xls
Recipes.doc
Work
Planning.doc
Downloads
FooBar.exe
ReadMe.txt使用以下参数调用时的输出:EnumerateFilesAndFolders"C:\Test",0
C:\Test Documents Downloads ReadMe.txt
使用以下参数调用时的输出:EnumerateFilesAndFolders"C:\Test",1,4
C:\Test
Documents
Personal
Work
Downloads
FooBar.exe
ReadMe.txt
热门推荐
10 新年的生日祝福语简短
11 婆婆蛋糕祝福语简短英文
12 升学祝福语简短的个性
13 小寒健康祝福语大全简短
14 春节拜年祝福语儿童简短
15 给女老板简短祝福语
16 好姐妹生日祝福语 简短
17 关于扬州的祝福语简短
18 祝福语简短大全微信