Class Module Alternative
Application.FileSearch - Class
Dim pLookIn As String
Dim pSearchSubFolders As Boolean
Dim pFileName As String
Public FoundFiles As New Collection
Public Property Get LookIn() As String
LookIn = pLookIn
End Property
Public Property Let LookIn(value As String)
pLookIn = value
End Property
Public Property Get SearchSubFolders() As Boolean
LookIn = pSearchSubFolders
End Property
Public Property Let SearchSubFolders(value As Boolean)
pSearchSubFolders = value
End Property
Public Property Get fileName() As String
fileName = pFileName
End Property
Public Property Let fileName(value As String)
pFileName = value
End Property
Public Function Execute() As Long
Dim ex As Long
Dim sLookIn As String
Dim sDirName As String
Dim sSubDir As String
Dim sFileName As String
Dim ff As FilesFound
Set ff = New FilesFound
sLookIn = LookIn
sDirName = Dir(sLookIn, vbDirectory)
sFileName = Dir(sLookIn & "\", vbNormal)
Do Until Len(sFileName) = 0
If sFileName Like fileName Then
ff.AddFile sLookIn, sFileName
FoundFiles.Add (ff.FoundFileFullName)
End If
sFileName = Dir
Loop
If SearchSubFolders Then
Do Until Len(sDirName) = 0
If GetAttr(sLookIn & sDirName) = vbDirectory Then
sSubDir = sDirName
Do Until Len(sFileName) = 0
If GetAttr(sDirName) = vbNormal Then
sFileName = sDirName
ff.AddFile sDirName, sFileName
FoundFiles.Add (ff)
End If
Loop
End If
sDirName = Dir
Loop
End If
Execute = FoundFiles.Count
End Function
The second I named FilesFound and the code is as follows:
Public FoundFileFullName As String
Public Function AddFile(path As String, fileName As String)
FoundFileFullName = path & "\" & fileName
End Function
To use it in your code just create the two class modules and then use it as such:
Dim sFile as String
Dim fs As New FileSearh
With fs
.LookIn = sPath
.SearchSubFolders = True
.fileName = "*"
If .Execute > 0 Then
For i = 1 To .FoundFiles.Count
sFile = .FoundFiles(i)
' your code here
Next
End If
End With
Example 2
Sub FileSearchByHavrda_Example_of_procedure_calling()
Dim FileNameWithPath As Variant
Dim ListOfFilenamesWithParh As New Collection ' create a collection of filenames
' Filling a collection of filenames (search Excel files including subdirectories)
Call FileSearchByHavrda(ListOfFilenamesWithParh, "C:\Temp", "*.xls", True)
' Print list to immediate debug window and as a message window
For Each FileNameWithPath In ListOfFilenamesWithParh ' cycle for list(collection) processing
Debug.Print FileNameWithPath & Chr(13)
MsgBox FileNameWithPath & Chr(13)
Next FileNameWithPath
' Print to immediate debug window and message if no file was found
If ListOfFilenamesWithParh.Count = 0 Then
Debug.Print "No file was found !"
MsgBox "No file was found !"
End If
End Sub
//------------------------------------------------------------------------------------------------
Private Sub FileSearchByHavrda(pFoundFiles As Collection, pPath As String, pMask As String, pIncludeSubdirectories As Boolean)
'
' Search files in Path and create FoundFiles list(collection) of file names(path included) accordant with Mask (search in subdirectories if enabled)
' 01.06.2009, Author: P. Havrda, Czech Republic
'
Dim DirFile As String
Dim CollectionItem As Variant
Dim SubDirCollection As New Collection
' Add backslash at the end of path if not present
pPath = Trim(pPath)
If Right(pPath, 1) <> "\" Then pPath = pPath & "\"
' Searching files accordant with mask
DirFile = Dir(pPath & pMask)
Do While DirFile <> ""
pFoundFiles.Add pPath & DirFile 'add file name to list(collection)
DirFile = Dir ' next file
Loop
' Procedure exiting if searching in subdirectories isn't enabled
If Not pIncludeSubdirectories Then Exit Sub
' Searching for subdirectories in path
DirFile = Dir(pPath & "*", vbDirectory)
Do While DirFile <> ""
' Add subdirectory to local list(collection) of subdirectories in path
If DirFile <> "." And DirFile <> ".." Then If ((GetAttr(pPath & DirFile) And vbDirectory) = 16) Then SubDirCollection.Add pPath & DirFile
DirFile = Dir 'next file
Loop
' Subdirectories list(collection) processing
For Each CollectionItem In SubDirCollection
Call FileSearchByHavrda(pFoundFiles, CStr(CollectionItem), pMask, pIncludeSubdirectories) ' Recursive procedure call
Next
End Sub
Application.FileSearch - Replacement
Set objCollection = Folder_GetFilesDirToCollection("C:\Temp\", "FileName_With_Wildcards*.csv")
Public Function Folder_GetFilesDirToCollection(ByVal sFolderPath As String, _
ByVal sPattern As String) As Collection
Dim objCollection As Collection
Dim sFileName As String
On Error GoTo AnError
sFileName = Dir(sFolderPath & sPattern)
Set objCollection = New Collection
Do While Len(sFileName) > 0
objCollection.Add (sFileName)
sFileName = Dir()
Loop
Set Folder_GetFilesDirToCollection = objCollection
Exit Function
AnError:
Call MsgBox(Err.Number & " - " & Err.Description)
End Function
Need code to get the last modified file
Public Function Folder_GetFileLastModified(ByVal sFolderPath As String, _
ByVal sPattern As String) As String
Dim objCollection As Collection
Dim sFileName As String
Dim dtLastModified As Date
Dim sLastModified As String
On Error GoTo AnError
sFileName = Dir(sFolderPath & sPattern)
Set objCollection = New Collection
sLastModified = sFileName
dtLastModified = DateSerial(2010, 1, 1)
Do While Len(sFileName) > 0
If (FileDateTime(sFolderPath & sFileName) > dtLastModified) Then
sLastModified = sFileName
End If
objCollection.Add (sFileName & "-" & FileDateTime(sFolderPath & sFileName))
sFileName = Dir()
Loop
Folder_GetFileLastModified = sLastModified
Exit Function
AnError:
Call MsgBox(Err.Number & " - " & Err.Description)
End Function
Public Sub Test_sPopulateHistory()
Dim vaFiles As Variant
vaFiles = Folder_GetFilesLastModifiedToArray("C:\Temp\", "FileName_With_Wildcards*.csv")
Stop
End Sub
Public Function Folder_GetFilesLastModifiedToArray(ByVal sFolderPath As String, _
ByVal sPattern As String) As Variant
Dim vaFiles() As Variant
Dim vaFilesCopy() As Variant
Dim sFileName As String
Dim iarraycount As Integer
On Error GoTo AnError
sFileName = Dir(sFolderPath & sPattern)
ReDim Preserve vaFiles(1, 2000)
Do While Len(sFileName) > 0
vaFiles(0, iarraycount) = sFileName
vaFiles(1, iarraycount) = FileDateTime(sFolderPath & sFileName)
sFileName = Dir()
iarraycount = iarraycount + 1
Loop
If iarraycount > 0 Then
ReDim Preserve vaFiles(1, iarraycount - 1)
ReDim Preserve vaFilesCopy(1, iarraycount - 1)
For iarraycount = 0 To UBound(vaFiles, 2)
vaFilesCopy(0, iarraycount) = vaFiles(0, UBound(vaFiles, 2) - iarraycount)
vaFilesCopy(1, iarraycount) = vaFiles(1, UBound(vaFiles, 2) - iarraycount)
Next iarraycount
End if
Folder_GetFilesLastModifiedToArray = vaFilesCopy
Exit Function
AnError:
Call MsgBox(Err.Number & " - " & Err.Description)
End Function
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext