xlsm file with vba code to save copy as xlsx on close

mandy4514

New Member
Joined
Apr 20, 2017
Messages
11
I have an xlsm file that I cannot open on excel online. So I am trying to create a code that every time I close the xlsm file it saves the information to a xlsx file that I can access on excel online.

I have the following code:

Sub SaveAs()

Dim FName As String
Dim FPath As String
Dim NewBook As Workbook

FPath = "C:\Users\arichards\Dropbox\Documents\Income vs Expens"
FName = "Income vs Expense" & Format(Date, "ddmmyyyy") & ".xlsx"

Set NewBook = Workbooks.Add

ThisWorkbook.Sheets("DataSort").Copy Before:=NewBook.Sheets(1)

If Dir(FPath & "" & FName) <> "" Then
MsgBox "File " & FPath & "" & FName & " already exists"
Else
NewBook.SaveAs Filename:=FPath & "" & FName
End If

End Sub



My issue with this code is error on every run that I cannot save to file type and save dialog appears. I want it to save automatically in the back ground. Help please?
 

Excel Facts

Fastest way to copy a worksheet?
Hold down the Ctrl key while dragging tab for Sheet1 to the right. Excel will make a copy of the worksheet.
Try
Code:
Sub SaveAs()

Dim FName As String
Dim FPath As String
Dim NewBook As Workbook

FPath = "C:\Users\DaveC\OneDrive\"
FName = "Income vs Expense" & Format(Date, "ddmmyyyy") & ".xlsx"

Set NewBook = Workbooks.Add

ThisWorkbook.Sheets("Task").Copy Before:=NewBook.Sheets(1)

If Dir(FPath & "" & FName) <> "" Then
MsgBox "File " & FPath & "" & FName & " already exists"
Else
NewBook.SaveAs FileName:=FPath & FName, FileFormat:=51
End If

End Sub
 
Upvote 0
Hello mandy4514,

This VBA macro will remove all VBA code from the worksheets and the workbook and save a copy as an XLSX workbook. The copy is saved to the same folder as the original. You can easily modify the macro to save it somewhere else.

Code:
Sub RemoveAllMacros()


    ' Written:  Decmber 05, 2015
    ' Author:   Leith Ross
    ' Summary:  Removes all macro code from the workbook and saves it as an XLSX workbook.
    
    Dim Newname     As String
    Dim OldName     As String
    Dim VBCode      As Object
    Dim VBComp      As Object
    Dim VBProj      As Object
    
        Set VBProj = ThisWorkbook.VBProject
        
        With VBProj
            For Each VBComp In .VBComponents
                Select Case VBComp.Type
                    Case 1, 2, 3
                        VBProj.VBComponents.Remove VBComp
                    Case 100
                        Set VBCode = VBComp.CodeModule
                        VBCode.DeleteLines 1, VBCode.CountOfLines
                End Select
            Next VBComp
        End With
        
        OldName = ThisWorkbook.FullName
        Newname = Left(OldName, InStrRev(OldName, ".")) & "xlsx"
        
        Application.DisplayAlerts = False
            ThisWorkbook.SaveAs Newname, xlOpenXMLWorkbook
            ThisWorkbook.Close SaveChanges:=True
        Application.DisplayAlerts = True
        
        Kill OldName
        
End Sub
 
Upvote 0

Forum statistics

Threads
1,223,888
Messages
6,175,212
Members
452,618
Latest member
Tam84

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top