Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

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?

like image 897
Eldar Agalarov Avatar asked Aug 20 '14 09:08

Eldar Agalarov


2 Answers

The OP said they want to rewrite their code "without FSO" but it doesn't make sense.

If the goal is to reduce the amount of code, simply make it a one-liner:

CreateObject("Scripting.FileSystemObject").DeleteFolder "x:\myFolder"

As requested, this permanently removes the folder and it's contents.


More Information:

  • Microsoft Docs : DeleteFolder Method
  • Ron de Bruin : Delete files and folders
like image 146
ashleedawg Avatar answered Sep 21 '22 22:09

ashleedawg


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.

like image 23
PaulFrancis Avatar answered Sep 22 '22 22:09

PaulFrancis