Dim FSO As Object
Sub RecursiveFileDeletion()
'Deletes files of a specified name pattern within a user-specified folder and its subfolders. Uses recursion.
Dim sNamePattern As String, TopFolderName As String
Dim TopFolderObj As Object
sNamePattern = "*.*" 'Delete just Excel files *.xl*, delete all files *.*
TopFolderName = Application.GetOpenFilename("Files (" & sNamePattern & "), " & sNamePattern, _
Title:="Pick any file in desired folder, then click Open, EE Q28312844")
If TopFolderName = "False" Then Exit Sub
TopFolderName = Left(TopFolderName, InStrRev(TopFolderName, Application.PathSeparator) - 1)
Application.ScreenUpdating = False
Set FSO = CreateObject("Scripting.FileSystemObject")
Set TopFolderObj = FSO.GetFolder(TopFolderName)
SubFolderRecursion TopFolderObj, sNamePattern
Set FSO = Nothing
MsgBox "Done"
End Sub
Sub SubFolderRecursion(OfFolder As Object, sNamePattern As String)
Dim SubFolder As Object
SearchFolder OfFolder.Path, sNamePattern
For Each SubFolder In OfFolder.SubFolders
SubFolderRecursion SubFolder, sNamePattern
SearchFolder SubFolder.Path, sNamePattern
On Error Resume Next
If Dir(SubFolder.Path & "\*.*") = "" Then RmDir SubFolder.Path 'Delete the subfolder if it is empty
On Error GoTo 0
Next SubFolder
End Sub
Sub SearchFolder(strPath As String, sNamePattern As String)
Dim strFile As String
strFile = Dir(strPath & "\" & sNamePattern)
On Error Resume Next
Do While strFile <> ""
If strFile <> ActiveWorkbook.Name Then Kill strPath & "\" & strFile
strFile = Dir
Loop
On Error GoTo 0
End Sub