Solved

Delete this

Posted on 2013-12-06
5
229 Views
Last Modified: 2013-12-07
Hello

I am trying to look for this thing but hard time finding this - using FSO -
1. open a main folder and then
2. go through each sub folder under that main folder and if you see any files, simply delete it

How can i do that in VBA?

Thank You
Rayne
0
Comment
Question by:Rayne
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 2
5 Comments
 
LVL 81

Accepted Solution

by:
byundt earned 500 total points
ID: 39702735
The following code will let the user pick any file in a folder. It will then delete any file within that folder plus any subfolders. The empty subfolders will not be deleted.
Dim FSO As Object

Sub SnarkHunt()
Dim TopFolderName As String
Dim TopFolderObj As Object
        'Input Path and Search Term
TopFolderName = Application.GetOpenFilename("Files (*.*), *.*", _
        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
Set FSO = Nothing
MsgBox "Done"
End Sub

Sub SubFolderRecursion(OfFolder As Object)

Dim SubFolder As Object
SearchFolder OfFolder.Path
For Each SubFolder In OfFolder.SubFolders
    SubFolderRecursion SubFolder
    SearchFolder SubFolder.Path
Next SubFolder
End Sub
    
Sub SearchFolder(strPath As String)
Dim fld As Object
Dim sfl As Object
Dim strFile As String
Dim strFirstAddress As String

On Error Resume Next

strFile = Dir(strPath & "\*.xls*")
Do While strFile <> ""
    If strFile <> ActiveWorkbook.Name Then
        Kill strPath & "\" & strFile
    End If
    strFile = Dir
Loop

On Error GoTo 0
End Sub

Open in new window

0
 

Author Comment

by:Rayne
ID: 39702739
thanks Bryan :)
0
 

Author Comment

by:Rayne
ID: 39702740
does what i need but in a very elegant way of coding - recursion - the very basics of CS classes :)
0
 
LVL 81

Expert Comment

by:byundt
ID: 39703137
I revised the code so it would delete the subfolders as well as the files. I also added the ability to specify a file naming pattern, i.e. delete only files like *.xl*, *.pdf or *.*
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

Open in new window


Brad
RecursiveFileDeleterQ28312844.xlsm
0
 

Author Comment

by:Rayne
ID: 39703976
Apologize for not getting your name right in the first place :(
I sometimes mistake one expert from other based of their usernames.

Thank you Brad - that is awesome - 5 stars for the file type thing :) as I knew there would be multiple file types situation possible in my case.
0

Featured Post

Salesforce Made Easy to Use

On-screen guidance at the moment of need enables you & your employees to focus on the core, you can now boost your adoption rates swiftly and simply with one easy tool.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Freeze panes is an option within all variants of Excel to enable parts of a sheet to remain stationary when the cursor is in another part of the sheet. This is a very useful feature which is overlooked or under used.
How to get Spreadsheet Compare 2016 working with the 64 bit version of Office 2016
Access reports are powerful and flexible. Learn how to create a query and then a grouped report using the wizard. Modify the report design after the wizard is done to make it look better. There will be another video to explain how to put the final p…
Polish reports in Access so they look terrific. Take yourself to another level. Equations, Back Color, Alternate Back Color. Write easy VBA Code. Tighten space to use less pages. Launch report from a menu, considering criteria only when it is filled…

759 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question