excelvbafilesystemobject

Remove directory and it's contents (files, subdirectories) without using FileSystemObject


I want to know if it's possible to rewrite this piece of code:

Private Sub PrepareDir(ByVal dir As String)
    Dim fso As New FileSystemObject
    If fso.FolderExists(dir) Then Call fso.DeleteFolder(dir, True)
    Call fso.CreateFolder(dir)
End Sub

With VBA statements: Kill, MkDir, etc. Most "difficult" part of this - remove non-empty directory. With FSO it can be done easily, but how it can be done without FSO?


Solution

  • This piece of ccode uses RmDir to remove the Folder. AFAIK, RmDir cannot delete the folder unless it is empty, so we first clear the content in the folder then remove the directory.

    Private Sub PrepareDirModified(dirStr As String)
    On Error Resume Next
        If Right(dirStr, 1) <> "\" Then dirStr = dirStr & "\"
        Kill dirStr & "*.*" 
        RmDir dirStr
        MkDir dirStr
    On Error GoTo 0
    End Sub
    

    Hope this helps.