Pearson Software Consulting Services
Working With Temporary Files And Folders
|
This module contains three procedures related to temporary files and folders. The first procedure, GetTempFolderName , returns the name of the folder that is designated for temporary files for the current user. It does not name or create a new folder. Instead, it returns the name of the folder that the system has specified for current user to store temporary files. The user is guaranteed to have write and create access to this folder. The second procedure on this page,
GetTemporaryFolderName
, is used to get the name of a temporary folder, and optionally create it.
This folder will be created in the user's system-designated temp folder,
returned by the function
GetTempFolderName. Documentation of each procedure is included in the
code itself. You can download all the VBA on this page and the GetSystemErrorMessageText and TrimToNull functions in this bas module file. The module is entirely self-contained. You do not need to add or change any code. All of the functions use the following code in the Declarations section of the code module. The functions also use the TrimToNull function, which is this function. TrimToNull is also included at the end of the code listing. Public Function TrimToNull(S As String) As String
''''''''''''''''''''''''''''''''''''''''''''''''''''
' TrimToNull
' This returns the portion of the string S that
' is to the left of the first vbNullChar character.
' If vbNullChar is not found, the entire string is
' returned.
''''''''''''''''''''''''''''''''''''''''''''''''''''
Dim Pos As Integer
Pos = InStr(1, S, vbNullChar)
If Pos > 0 Then
TrimToNull = Left(S, Pos - 1)
Else
TrimToNull = S
End If
End Function
Option Explicit Public Function GetTempFolderName( _
Optional IncludeTrailingSlash As Boolean = False) As String
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' GetTempFolder
' This procedure returns the name of the folder that the system has designated
' for temporary files for the current user.
' Returns the name of the folder or vbNullString if an error
' occurred. The argument IncludeTrailingSlash indicates whether to include a
' trailing slash at the end of the folder name.
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Dim TempPath As String
Dim Length As Long
Dim Result As Long
Dim ErrorNumber As Long
Dim ErrorText As String
''''''''''''''''''''''''''''''''''''''
' Initialize the variables
''''''''''''''''''''''''''''''''''''''
TempPath = String(MAX_PATH, " ")
Length = MAX_PATH
'''''''''''''''''''''''''''''''''''''''''''''''''
' Get the Temporary Path using GetTempPath.
'''''''''''''''''''''''''''''''''''''''''''''''''
Result = GetTempPath(Length, TempPath)
If Result = 0 Then
'''''''''''''''''''''''''''''''''''''
' An error occurred
'''''''''''''''''''''''''''''''''''''
ErrorNumber = Err.LastDllError
ErrorText = GetSystemErrorMessageText(ErrorNumber)
MsgBox "An error occurred getting the temporary folder" & _
" from the GetTempFolderName function: " & vbCrLf & _
"Error: " & CStr(ErrorNumber) & " " & ErrorText
GetTempFolderName = vbNullString
Exit Function
Else
'''''''''''''''''''''''''''''''''''''''
' No error, but the buffer may have
' been too small.
'''''''''''''''''''''''''''''''''''''''
If Result > Length Then
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' The buffer TempPath was too small to hold the folder name.
' This should never happen if MAX_PATH is set to the proper
' value.
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
MsgBox "The TempPath buffer is too small. It is allocated at " & _
CStr(Length) & " characters." & vbCrLf & _
"The required buffer size is: " & CStr(Result) & " characteres.", _
vbOKOnly, "GetTempFolderName"
GetTempFolderName = vbNullString
Exit Function
End If
' trim up the TempPath. It includes a trailing "\"
TempPath = TrimToNull(Text:=TempPath)
If IncludeTrailingSlash = False Then
'''''''''''''''''''''''''''''''''''''''''''''''''
' If IncludeTrailingSlash is false, get rid of
' the trailing slash.
'''''''''''''''''''''''''''''''''''''''''''''''''
TempPath = Left(TempPath, Len(TempPath) - 1)
End If
End If
GetTempFolderName = TempPath
End Function
GetTemporaryFolderName Public Function
GetTemporaryFolderName(Optional Create As Boolean = False) As String GetTempFile Public Function GetTempFile(Optional InFolder As String = vbNullString, _
Optional FileNamePrefix As String = vbNullString, _
Optional Extension As String = vbNullString, _
Optional CreateFile As Boolean = True)
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' GetTempFileName
' This function will return the name of a temporary file, optionally suffixed with the
' string in the Extension variable. It will optionally create the file.
'
' If InFolder specifies an existing folder, the file will be created in that folder.
' If InFolder specifies a non-existant folder, the procedure will attempt to create
' the folder.
' If InFolder is vbNullString, the procedure will call GetTempFolderName to get
' the folder designated for temporary files.
' InFolder must be a fully qualified path. That is, a folder name begining with a
' network prefix "\\" or containing ":".
' If FileNamePrefix is specified, the file name will begin with the first three
' characters of this string. In this case, FileNamePrefix must be three characters
' with no spaces or illegal file name characters. These are validated with
' PathGetCharType. If FileNamePrefix is vbNullString, the value of C_DEFAULT_PREFIX
' will be used.
' If FileNamePrefix contains spaces or invalid characters, an error occurs.
'
' If Extension is specified, the filename will have that Extension. If must be three
' valid characters (no spaces). The characters are validated with PathGetCharType.
' If Extension is vbNullString the default extension from GetTempFileName ("tmp") is
' used. Do NOT put the period in front of the extension (e.g., use "xls" not ".xls").
' If Extension is a single space, the file name will have no extension.
'
' If CreateFile is omitted or True, the file will be created. If CreateFile is false,
' the file is not created. (Actually, it will be created by GetTempFileName and then
' KILLed.)
'
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Dim PathBuffer As String
Dim Prefix As String
Dim FolderPath As String
Dim Res As Long
Dim FileName As String
Dim ErrorNumber As Long
Dim ErrorText As String
Dim FileNumber As Integer
Const C_DEFAULT_PREFIX = "TMP"
FileName = String$(MAX_PATH, vbNullChar)
If InFolder = vbNullString Then
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' InFolder was an empty string. Call GetTempFolderName
' to get a temporary folder name.
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''
PathBuffer = GetTempFolderName(IncludeTrailingSlash:=True)
Else
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' test to see if we have an absolute path
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
If (Left(InFolder, 2) = "\\") Or _
(InStr(1, InFolder, ":", vbTextCompare) > 0) Then
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' We have an absolute path. Test whether the folder exists.
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
If Dir(InFolder, vbHidden + vbSystem + vbHidden + _
vbNormal + vbDirectory) = vbNullString Then
'''''''''''''''''''''''''''''''''''''''''''''''''''
' InFolder does not exist. Try to create it.
'''''''''''''''''''''''''''''''''''''''''''''''''''
On Error Resume Next
Err.Clear
MkDir InFolder
If Err.Number <> 0 Then
MsgBox "An error occurred creating the '" & InFolder _
& "' folder." & vbCrLf & _
"Error: " & CStr(Err.Number) & vbCrLf & _
"Description: " & Err.Description, vbOKOnly, "GetTempFileName"
GetTempFile = vbNullString
Exit Function
Else
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' MkDir succussfully created the folder. Set PathBuffer to the new
' folder name.
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
PathBuffer = InFolder
End If
Else
'''''''''''''''''''''''''''''''''''''''''''''''''''
' InFolder exists. Set the PathBuffer variable to InFolder
'''''''''''''''''''''''''''''''''''''''''''''''''''
PathBuffer = InFolder
End If
Else
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' We don't have a fully qualified path. Get out with an error message.
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
MsgBox "The InFolder parameter to GetTempFile is not an absolute file name.", _
vbOKOnly, "GetTempFileName"
GetTempFile = vbNullString
Exit Function
End If ' LEFT
End If ' InFolder = vbNullString
''''''''''''''''''''''''''''''''''''''''''
' Ensure we have a '\' at the end of the
' path.
'''''''''''''''''''''''''''''''''''''''''
If Right(PathBuffer, 1) <> "\" Then
PathBuffer = PathBuffer & "\"
End If
If FileNamePrefix = vbNullString Then
'''''''''''''''''''''''''''''''''''''''''
' FileNamePrefix is empty, use 'tmp'
'''''''''''''''''''''''''''''''''''''''''
Prefix = C_DEFAULT_PREFIX
Else
If IsValidFileNamePrefixOrExtension(Spec:=FileNamePrefix) = False Then
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' FileNamePrefix is invalid. Get out with an error.
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
MsgBox "The file name prefix '" & FileNamePrefix & "' is invalid.", _
vbOKOnly, "GetTempFileName"
GetTempFile = vbNullString
Exit Function
Else
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' FileNamePrefix is valid.
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Prefix = FileNamePrefix
End If
End If
''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' Get the temp file name. GetTempFileName will automatically
' create the file. If CreateFile is False, we'll have
' to Kill the file. We set wUnique to 0 to ensure that
' the filename will be unique. This has the side effect
' of creating the file.
''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Res = GetTempFileName(lpszPath:=PathBuffer, _
lpPrefixString:=Prefix, _
wUnique:=0, _
lpTempFileName:=FileName)
If Res = 0 Then
''''''''''''''''''''''''''''
' An error occurred. Get out
' with an error message.
''''''''''''''''''''''''''''
ErrorNumber = Err.LastDllError
ErrorText = GetSystemErrorMessageText(ErrorNumber)
MsgBox "An error occurred with GetTempFileName" & vbCrLf & _
"Error: " & CStr(ErrorNumber) & vbCrLf & _
"Description: " & ErrorText, vbOKOnly, "GetTempFileName"
GetTempFile = vbNullString
Exit Function
End If
''''''''''''''''''''''''''''''''''''''''''
' GetTempFileName put the file name in the
' FileName variable, ending with a vbNullChar.
' Trim to the the vbNullChar.
'''''''''''''''''''''''''''''''''''''''''''
FileName = TrimToNull(Text:=FileName)
'''''''''''''''''''''''''''''''''''''''''''
' GetTempFileName created a file with an
' extension of "tmp". If Extension was
' specified and is not a null string,
' change the extension to the specified
' extension. We'll use the same validation
' routine as we did for the prefix.
'''''''''''''''''''''''''''''''''''''''''''
If Extension = vbNullString Then
'''''''''''''''''''''''''''''''''''''''''''''''''''''''
' If Extension is vbNullString, use the extension
' created by GetTEmpFileName ("tmp"). Test whether
' CreateFile is False. If False, we have to kill the
' newly created file.
'''''''''''''''''''''''''''''''''''''''''''''''''''''''
If CreateFile = False Then
On Error Resume Next
Kill FileName
Else
''''''''''''''''''''''''''''''''''
' CreateFile was true. Leave
' the newly created file in place
''''''''''''''''''''''''''''''''''
End If
Else ' Extension is not vbNullString
If Extension = " " Then
''''''''''''''''''''''''''''''''''''
' An Extension value of " " indicates
' that the filename should have no
' extension. First Kill FileName, modify
' the variable to have no extension, and then
' see if we need to create the file. If CreateFile
' if False, don't create the file. If True,
' create the file by openning it and then
' immmediately close it.
''''''''''''''''''''''''''''''''''''
On Error Resume Next
Kill FileName
On Error GoTo 0
FileName = Left(FileName, Len(FileName) - 4)
If CreateFile = True Then
''''''''''''''''''''''''''''''''''''''''
' Create the file by opening it for
' output, then immediately closing it.
''''''''''''''''''''''''''''''''''''''''
FileNumber = FreeFile
Open FileName For Output Access Write As #FileNumber
Close #FileNumber
Else
'''''''''''''''''''''''''''''''''''''''''
' CreateFile was false. Since we've already
' Killed the file created by GetTempFileName,
' do nothing.
''''''''''''''''''''''''''''''''''''''''''
End If
Else
If IsValidFileNamePrefixOrExtension(Spec:=Extension) Then
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' If we have a valid extension, kill the existing filename
' and the recreate the file with the new extension.
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
On Error Resume Next
Kill FileName
On Error GoTo 0
FileName = Left(FileName, Len(FileName) - 4) & "." & Extension
If CreateFile = True Then
FileNumber = FreeFile
Open FileName For Output Access Write As #FileNumber
Close #FileNumber
Else
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' CreateFile was false. Since we've already killed the
' filename created by GetTempFileName, do nothing.
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
End If
Else
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' The extension was not valid. Display an error and get out.
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
MsgBox "The extension '" & Extension & "' is not valid.", _
vbOKOnly, "GetTempFileName"
GetTempFile = vbNullString
Exit Function
End If
End If
End If
''''''''''''''''''''''''''''''''''''''''''''
' We were successful. Return the filename.
''''''''''''''''''''''''''''''''''''''''''''
GetTempFile = FileName
End Function
Private Function IsValidFileNamePrefixOrExtension(Spec As String) As Boolean
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' IsValidFileNamePrefix
' This returns TRUE if Prefix is a valid 3 character filename
' prefix used with GetTempFileName
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Const GCT_INVALID As Long = &H0
Const GCT_SEPARATOR As Long = &H8
Const GCT_WILD As Long = &H4
Const GCT_LFNCHAR As Long = &H1
Const GCT_SHORTCHAR As Long = &H2
Dim Ndx As Long
Dim B As Byte
'''''''''''''''''''''''''''''''''
' prefix contains a space. error.
'''''''''''''''''''''''''''''''''
If InStr(1, Spec, " ") > 0 Then
IsValidFileNamePrefixOrExtension = False
Exit Function
End If
'''''''''''''''''''''''''''''''''
' prefix is not 3 chars. error.
'''''''''''''''''''''''''''''''''
If Len(Spec) <> 3 Then
IsValidFileNamePrefixOrExtension = False
Exit Function
End If
'''''''''''''''''''''''''''''''''
' Loop through the 3 characters
' of Prefix. If we find an
' invalid character, get out with
' a result of False.
'''''''''''''''''''''''''''''''''
For Ndx = 1 To 3
B = CByte(Asc(Mid(Spec, Ndx, 1)))
Select Case PathGetCharType(B)
Case GCT_INVALID, GCT_SEPARATOR, GCT_WILD
IsValidFileNamePrefixOrExtension = False
Exit Function
Case GCT_LFNCHAR, GCT_SHORTCHAR, GCT_LFNCHAR + GCT_SHORTCHAR
Case Else
IsValidFileNamePrefixOrExtension = False
Exit Function
End Select
Next Ndx
'''''''''''''''''''''''''''''''''
' If we made it out of the loop,
' the Prefix was valid. Return
' True.
'''''''''''''''''''''''''''''''''
IsValidFileNamePrefixOrExtension = True
End Function
Public Function TrimToNull(S As String) As String
''''''''''''''''''''''''''''''''''''''''''''''''''''
' TrimToNull
' This returns the portion of the string S that
' is to the left of the first vbNullChar character.
' If vbNullChar is not found, the entire string is
' returned.
''''''''''''''''''''''''''''''''''''''''''''''''''''
Dim Pos As Integer
Pos = InStr(1, S, vbNullChar)
If Pos > 0 Then
TrimToNull = Left(S, Pos - 1)
Else
TrimToNull = S
End If
End Function
|
|
|
Created By Chip Pearson and
Pearson Software Consulting, LLC
This Page:
Updated: November 06, 2013
MAIN PAGE
About This Site
Consulting
Downloads
Page Index
Search
Topic Index
What's New
Links
Legalese And Disclaimers
chip@cpearson.com
© Copyright 1997-2007 Charles H. Pearson