How to programmatically save a file to a network drive in Excel
This article was previously published under Q213641
For a Microsoft Excel 97 and earlier and Microsoft Excel 98 Macintosh Edition and earlier version of this article, see 141512.
In Microsoft Excel, you can save a file to any drive to which you havewrite and delete privileges. In addition, you can use a Microsoft VisualBasic for Applications macro to save the active workbook and use a variablefor the file name. You can use variables from the ActiveWorkbook.Nameproperty, from input box data, or from a cell reference.
NOTE: If you use the full path for the file name, Microsoft Excel will know exactly where to save the file. If the path is not given, Microsoft Excel will save the file to the currently active directory or folder.
Microsoft provides programming examples for illustration only, without warranty either expressed or implied. This includes, but is not limited to, the implied warranties of merchantability or fitness for a particular purpose. This article assumes that you are familiar with the programming language that is being demonstrated and with the tools that are used to create and to debug procedures. Microsoft support engineers can help explain the functionality of a particular procedure, but they will not modify these examples to provide added functionality or construct procedures to meet your specific requirements.
Sample Macro 1Save the active workbook with a variable to a specified path. To do this,use the following macro:
Sub SaveWithVariable() Dim MyFile As String MyFile = ActiveWorkbook.Name ' Do not display the message about overwriting the existing file. Application.DisplayAlerts = False ' Save the active workbook with the name of the ' active workbook. Save it on the E drive to a folder called ' "User" with a subfolder called "JoeDoe." ActiveWorkbook.SaveAs Filename:="E:\User\JoeDoe\" & MyFile ' Close the workbook by using the following. ActiveWorkbook.Close End Sub
Sample Macro 2Use a file name stored in a cell and save the file to the network server.To do this, use the following macro:
Sub SaveWithVariableFromCell() Dim SaveName As String SaveName = ActiveSheet.Range("A1").Text ActiveWorkbook.SaveAs Filename:="E:\User\JoeDoe\" & _ SaveName & ".xls" End Sub
XL2000 9.00 xl2002 xl2003 XL2007 XL2003
Article ID: 213641 - Last Review: 01/24/2007 02:54:35 - Revision: 5.1
Microsoft Office Excel 2007, Microsoft Office Excel 2003, Microsoft Excel 2002 Standard Edition, Microsoft Excel 2000 Standard Edition
- kbdtacode kbhowto kbprogramming KB213641