Export A Query To Excel Using New FileDialog Object
Office 2007 and later versions provide the new Microsoft Office 12.0 or Later Object Library which can be used to create File Save Dialog Boxes, simplifying the coding required.
Details on this technology can be viewed at:
In the following example, I illustrate the form which calls the Save FileDialog Box, and then exports a query to Excel in the target directory and file name selected by the user.
Program Code
' *********************************************************************************
' This Form Exports A Query To Excel Targeting a Selected Directory And File Name
' Using The File Save Dialog Box Procedure
' *********************************************************************************
Option Compare Database
Option Explicit
Private Sub cmdExportToExcel_Click()
' *********************************************************************************
' This Form Exports A Query To Excel To A Selected Directory And File Name
' *********************************************************************************
Dim strTitle As String
Dim strFileNameToSave As String
Dim strFilePathAndName As String
' *********************************************************************************
' Set Up Parameters For The Call To the Save Dialog Box
' *********************************************************************************
strTitle = "Export Style Master to Excel"
strFileNameToSave = "StyleMaster-" & Format(Now(), "mm-dd-yyyy-hh-mm-ss") & ".xls"
' *********************************************************************************
' Call The Save Dialog Box With Parameters And Receive The Full Path And File Name
' Which Will Be The Target For the Excel Export
' *********************************************************************************
strFilePathAndName = cmdFileDialogSave(strTitle, strFileNameToSave)
' *********************************************************************************
' Exit if the user pressed cancel
' *********************************************************************************
If strFilePathAndName = "" Then
MsgBox ("File Not Saved")
Exit Sub
End If
' *********************************************************************************
' Transfer the query to Excel
' *********************************************************************************
DoCmd.TransferSpreadsheet acExport, acSpreadsheetTypeExcel8, _
"qryExportStyleMaster", strFilePathAndName, True
' *********************************************************************************
' Close The Form
' *********************************************************************************
DoCmd.Close acForm, "frmExportExcel"
End Sub
Option Compare Database
Option Explicit
Public Function cmdFileDialogSave(strTitle As String, strFileName As String) As String
'*********************************************************************
' This Module Requires Including Microsoft OFFICE 12.0 Object Library
'*********************************************************************
Dim fDialog As Office.FileDialog
Dim strFileSelected As String
'****************************************************************
' Instantiate The File Dialog Object
'****************************************************************
Set fDialog = Application.FileDialog(msoFileDialogSaveAs)
'****************************************************************
' Set Up The File Dialog Parameters
'****************************************************************
With fDialog
.AllowMultiSelect = False
.Title = strTitle
.InitialFileName = strFileName
'****************************************************************
' Present the File Save Dialog Box
'****************************************************************
If .Show = True Then
strFileSelected = .SelectedItems(1)
Else
strFileSelected = ""
End If
End With
'****************************************************************
' Return The Full Path and File Name
'****************************************************************
cmdFileDialogSave = strFileSelected
End Function
