Code Snippets

rename an existing file
delete a file in a folder
copy a file to a different folder
move a file to a different folder


File_ReadAllowed

Function File_ReadAllowed(sFullPath As String) As Boolean 
Dim fso As New Scripting.FileSystemObject
Dim fsofile As Scripting.File
   Set fsofile = fso.GetFile(sfullpath)
   Set fso = Nothing
End Function

Finding a File



Writing to a Log File



Reading a File


Dim fso As Scripting.FileSystemObject 
Dim fsoTextStream As Scripting.TextStream

Set fso = New Scripting.FileSystemObject
Set fsoTextStream = fso.OpenTextFile(sfullpath, ForReading)

With fsoTextStream
   Do While Not .AtEndOfStream
      stext = .ReadLine
   Loop
End With


Sub ShowFreeSpace(drvPath) 
    Dim fs, d, s
    Set fs = CreateObject("Scripting.FileSystemObject")
    Set d = fs.GetDrive(fs.GetDriveName(drvPath))
    s = "Drive " & UCase(drvPath) & " - "
    s = s & d.VolumeName & vbCrLf
    s = s & "Free Space: " & FormatNumber(d.FreeSpace/1024, 0)
    s = s & " Kbytes"
    MsgBox s
End Sub

Sub ShowDriveList 
    Dim fs, d, dc, s, n
    Set fs = CreateObject("Scripting.FileSystemObject")
    Set dc = fs.Drives
    For Each d in dc
        s = s & d.DriveLetter & " - "
        If d.DriveType = Remote Then
            n = d.ShareName
        Else
            n = d.VolumeName
        End If
        s = s & n & vbCrLf
    Next
    MsgBox s
End Sub

Returns just the filename only

Private Function FileNameOnly(sFullPathName) As String 
Dim icharcount As Integer
Dim ipathlength As Integer
Dim stemp As String
   ipathlength = Len(sFullPathName)
   stemp = ""
   For icharcount = ipathlength To 1 Step -1
      If Mid(sFullPathName, icharcount, 1) = Application.PathSeparator Then
          FileNameOnly = stemp
          Exit Function
      End If
      stemp = Mid(sFullPathName, icharcount, 1) & stemp
   Next icharcount
   FileNameOnly = sFullPathName
End Function

Checks if a directory path exists

Private Function DirectoryExists(sFullPathName) As Boolean 
Dim stemp As String
    On Error Resume Next
    stemp = GetAttr(sFullPathName) And 0
    If Err = 0 Then DirectoryExists = True _
      Else DirectoryExists = False
End Function

' 32-bit API declarations

Private Declare Function GetDriveType32 Lib "kernel32" _ 
    Alias "GetDriveTypeA" (ByVal nDrive As String) As Long

Private Declare Function GetLogicalDriveStrings Lib "kernel32" _
  Alias "GetLogicalDriveStringsA" (ByVal nBufferLength As Long, _
  ByVal lpBuffer As String) As Long

Private Declare Function GetDiskFreeSpace Lib "kernel32" _
 Alias "GetDiskFreeSpaceA" (ByVal lpRootPathName As String, _
 lpSectorsPerCluster As Long, lpBytesPerSector As Long, _
 lpNumberOfFreeClusters As Long, lpTtoalNumberOfClusters As Long) _
 As Long


Function FreeDiskSpace(DriveLetter As String) As Double 
' Returns the number of free bytes for a drive

    Dim SectorsPerCluster As Long
    Dim BytesPerSector As Long
    Dim NumberofFreeClusters As Long
    Dim TotalClusters As Long

    DLetter = Left(DriveLetter, 1) & ":\"
    x = GetDiskFreeSpace(DLetter, SectorsPerCluster, _
      BytesPerSector, NumberofFreeClusters, TotalClusters)
    
    If x = 0 Then 'Error occurred
        FreeDiskSpace = -99 'Assign an arbitrary error value
        Exit Function
    End If
    FreeDiskSpace = _
      SectorsPerCluster * BytesPerSector * NumberofFreeClusters
End Function


Function TotalDiskSpace(DriveLetter As String) As Long 
' Returns the total storage capacity for a drive
    
    Dim SectorsPerCluster As Long
    Dim BytesPerSector As Long
    Dim NumberofFreeClusters As Long
    Dim TotalClusters As Long

    DLetter = Left(DriveLetter, 1) & ":\"
    x = GetDiskFreeSpace(DLetter, SectorsPerCluster, _
      BytesPerSector, NumberofFreeClusters, TotalClusters)
    
    If x = 0 Then 'Error occurred
        TotalDiskSpace = -99 'Assign an arbitrary error value
        Exit Function
    End If
    TotalDiskSpace = _
      SectorsPerCluster * BytesPerSector * TotalClusters
End Function


Function DriveType(DriveLetter As String) As String 
' Returns a string that describes the drive type
    
    DLetter = Left(DriveLetter, 1) & ":"
    DriveCode = GetDriveType32(DLetter)
       
    Select Case DriveCode
        Case 1: DriveType = "Local"
        Case 2: DriveType = "Removable"
        Case 3: DriveType = "Fixed"
        Case 4: DriveType = "Remote"
        Case 5: DriveType = "CD-ROM"
        Case 6: DriveType = "RAM Disk"
        Case Else: DriveType = "Unknown Drive Type"
    End Select
End Function


Function DriveExists(DriveLetter As String) As Boolean 
' Returns True if a specified drive letter exists
    
    Dim Buffer As String * 255
    Dim BuffLen As Long
   
    DLetter = Left(DriveLetter, 1)
    BuffLen = GetLogicalDriveStrings(Len(Buffer), Buffer)

    DriveExists = False
' Search for the string
    For i = 1 To BuffLen
        If UCase(Mid(Buffer, i, 1)) = UCase(DLetter) Then
' Found it
            DriveExists = True
            Exit Function
        End If
    Next i
End Function


Function NumberofDrives() As Integer 
' Returns the number of drives
    
    Dim Buffer As String * 255
    Dim BuffLen As Long
    Dim DriveCount As Integer
   
    BuffLen = GetLogicalDriveStrings(Len(Buffer), Buffer)
    DriveCount = 0
' Search for a null -- which separates the drives
    For i = 1 To BuffLen
        If Asc(Mid(Buffer, i, 1)) = 0 Then _
          DriveCount = DriveCount + 1
    Next i
    NumberofDrives = DriveCount
End Function

Function DriveName(index As Integer) As String 
' Returns the drive letter using an index
' Returns an empty string if index > number of drives
    
    Dim Buffer As String * 255
    Dim BuffLen As Long
    Dim TheDrive As String
    Dim DriveCount As Integer
   
    BuffLen = GetLogicalDriveStrings(Len(Buffer), Buffer)

' Search thru the string of drive names
    TheDrive = ""
    DriveCount = 0
    For i = 1 To BuffLen
        If Asc(Mid(Buffer, i, 1)) <> 0 Then _
          TheDrive = TheDrive & Mid(Buffer, i, 1)
        If Asc(Mid(Buffer, i, 1)) = 0 Then 'null separates drives
            DriveCount = DriveCount + 1
            If DriveCount = index Then
                DriveName = UCase(Left(TheDrive, 1))
                Exit Function
            End If
            TheDrive = ""
        End If
    Next i
End Function


Sub ShowDriveInfo()
' This sub writes information for all drives
' to a range of cells
' Demonstrates the use of the custom drive functions

    Dim i As Integer
    Dim DLetter As String
    Dim NumDrives As Integer
        
    NumDrives = NumberofDrives()

' Write info for all drives to active cell location
    If TypeName(Selection) <> "Range" Then
        MsgBox "Select a cell"
        Exit Sub
    End If
    
' Insert headings
    Application.ScreenUpdating = False
    With ActiveCell
        .Offset(0, 0).Value = "Drive"
        .Offset(0, 1).Value = "Type"
        .Offset(0, 2).Value = "Bytes Free"
        .Offset(0, 3).Value = "Total Bytes"
        
' Insert data for each drive
        For i = 1 To NumDrives
        DLetter = DriveName(i)
        Drive name
        .Offset(i, 0).Value = DLetter & ":\"
        Drive type
        .Offset(i, 1) = DriveType(DLetter)
' Free space
        .Offset(i, 2) = Format(FreeDiskSpace(DLetter), "#,##0")
' Total space
        .Offset(i, 3) = Format(TotalDiskSpace(DLetter), "#,##0")
        Next i
' Format the table
        .AutoFormat Format:=xlSimple, Number:=True, Font:=True, _
        Alignment:=True, Border:=True, Pattern:=True, Width:=True
    End With
End Sub

File Association


Private Declare Function FindExecutableA Lib "shell32.dll" _ 
    (ByVal lpFile As String, ByVal lpDirectory As String, _
    ByVal lpResult As String) As Long

Function GetExecutable(strFile As String) As String
Dim strPath As String
Dim intLen As Integer
    strPath = String(255, 0)
    intLen = FindExecutableA(strFile, "\", strPath)
    If intLen > 32 Then
        GetExecutable = Left(strPath, intLen)
    Else
       GetExecutable = ""
    End If
End Function

Sub GetFileName()
Dim fname As String
    fname = Application.GetOpenFilename
    MsgBox "The executable file is " & GetExecutable(fname), vbInformation, fname
End Sub

Folder recursion using the FileSystemObject

Sub EnumerateFilesAndFolders( _ 
     FolderPath As String, _
     Optional MaxDepth As Long = -1, _
     Optional CurrentDepth As Long = 0, _
     Optional Indentation As Long = 2)
   
     Dim FSO As Scripting.FileSystemObject
     Set FSO = New Scripting.FileSystemObject
     
'Check the folder exists
     If FSO.FolderExists(FolderPath) Then
         Dim fldr As Scripting.Folder
         Set fldr = FSO.GetFolder(FolderPath)
         
'Output the starting directory path
         If CurrentDepth = 0 Then
           Debug.Print fldr.Path
         End If
         
'Enumerate the subfolders
         Dim subFldr As Scripting.Folder
         For Each subFldr In fldr.SubFolders
             Debug.Print Space$((CurrentDepth + 1) * Indentation) & subFldr.Name
             If CurrentDepth < MaxDepth Or MaxDepth = -1 Then
'Recursively call EnumerateFilesAndFolders
                 EnumerateFilesAndFolders subFldr.Path, MaxDepth, CurrentDepth + 1, Indentation
             End If
         Next subFldr
         
'Enumerate the files
         Dim fil As Scripting.File
         For Each fil In fldr.Files
             Debug.Print Space$((CurrentDepth + 1) * Indentation) & fil.Name
         Next fil
     End If
 End Sub

© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext