Excel vba save as no macro

 

PATRI0T

Пользователь

Сообщений: 5
Регистрация: 13.11.2015

#1

05.10.2017 11:28:30

Добрый день.
В Excel сделал небольшую форму для приема заказов на мебельном производстве.
И потом заявку нужно сохранить в отдельном .xls файле , для импорта в другую программу.
Код макроса содержится на листе + отдельный модуль…
На листе обработчик на событие Workbook_Open

Что делаю:
1.Копирую текущий лист в новую книгу, удаляю все лишнее на листе (управляющие кнопки (shape), лишние строки .итд)
2. Удаляю макросы (внизу код)
3. сохраняю как файл .xls (xlExcel8)

Код
Sheets("Новый Заказ").Copy
Call Delete_Macroses
ActiveWorkbook.SaveAs FileName:=ПутьСохранения & "" & Fname, FileFormat:=xlExcel8, Password:="", WriteResPassword:="", ReadOnlyRecommended:=False, CreateBackup:=False

Этой процедурой удаляю макросы (пытаюсь)

Код
Sub Delete_Macroses()
    Dim oVBComponent As Object, lCountLines As Long
    'Проверяем, защищен проект или нет
 
    For Each oVBComponent In ActiveWorkbook.VBProject.VBComponents
        On Error Resume Next
        With oVBComponent
            Select Case .Type
            Case 1    'Модули
                .Collection.Remove oVBComponent
            Case 2    'Модули Класса
                .Collection.Remove oVBComponent
            Case 3    'Формы
                .Collection.Remove oVBComponent
            Case 100    'ЭтаКнига, Листы
                    lCountLines = .CodeModule.CountOfLines
                    .CodeModule.DeleteLines 1, lCountLines
            End Select
        End With
    Next
    Set oVBComponent = Nothing
End Sub

В результате
Файл занимает 52 КБ, а не 9, как если бы я сохранил его вручную в формат .xls
И при открытии всплывает сообщение «включить содержимое».

Что не так? Что не удаляется?

Вопрос.
А можно ли сохранить заявку из этого файла без макросов, не прибегая к обращению к объектной модели?
Т.к. этот файлик рассылается клиентам, и нужно обязательно делать соотв. настройки у них..
А клиенты разные и нервные.. Можно ли как-то этого избежать?

Прикрепленные файлы

  • 2017-10-05_110247.png (22.83 КБ)
  • Иванов 444. (от 05.10.2017 11.08.50).xls (55.5 КБ)

 

_Igor_61

Пользователь

Сообщений: 3007
Регистрация: 18.07.2016

Можно. Побаловался макрорекордером и у меня получилось  :)  

 

PATRI0T

Пользователь

Сообщений: 5
Регистрация: 13.11.2015

#3

06.10.2017 08:17:17

Спасибо за ответ
Только я ничего не понял, почему у меня не работает. Вроде код такой же :)

А зачем это?

Код
Kill Addr & "Файл без макросов 2007.xlsx
 

Александр П.

Пользователь

Сообщений: 1147
Регистрация: 16.03.2016

#4

06.10.2017 08:53:07

PATRI0T, Код ниже удаляет весь код во всех модулях активной книги.

Код
Sub test()
Set VBComp = ActiveWorkbook.VBProject.VBComponents
 For Each cl In VBComp
   cl.CodeModule.DeleteLines 1, cl.CodeModule.CountOfLines
 Next
End Sub
 

_Igor_61

Пользователь

Сообщений: 3007
Регистрация: 18.07.2016

#5

06.10.2017 09:07:38

Цитата
PATRI0T написал: не понял, почему у меня не работает.

Покажите Ваш файл с кодом, который не работает. Смею предположить, что Вы что-то не так или не туда вставили или что-то не так сделали, а так же невнимательно посмотрели код, иначе не возникло бы вопроса:[QUOTE]PATRI0T написал: А зачем это?  Kill Addr & «Файл без макросов 2007.xlsx[/CODE]
В модуле к этой и еще к нескольким строкам есть комментарии.
Так же обратите внимание на названия файлов в коде. Мои названия поменяйте на Ваши

 

_Igor_61

Пользователь

Сообщений: 3007
Регистрация: 18.07.2016

Александр, здравствуйте! Но тогда пользователю нужно лезть в параметры, ставить доверенный доступ и перезапускать приложение, что для пользователя, думаю не очень удобно. Поэтому по-моему проще это все сделать просто пересохранением файлов, а потом лишний файл удалить. ИМХО, конечно  :)  

 

_Igor_61, ну так, наше дело предложить вариант  :) .
У ТСа так же, может быть только 2003 версия офиса, без конвертера. Тогда в .xlsx он не сможет сохранять. А так, была уже похожая тема на форуме.

Изменено: Александр П.06.10.2017 10:19:58

 

sokol92

Пользователь

Сообщений: 4445
Регистрация: 10.09.2017

Уважаемый PATRI0T, в приложенном к сообщению файле макросов нет, зато есть два «битых» имени книги. Удалите их через «Диспетчер имен» и проблема с открытием должна уйти.

 

_Igor_61

Пользователь

Сообщений: 3007
Регистрация: 18.07.2016

#9

07.10.2017 00:34:38

Цитата
Александр П. написал:
У ТСа так же, может быть только 2003 версия офиса

Да, если это так, то не удивительно, что у него мой макрос не работает, если он его в xls помещает.  Но почему-то он про этот момент молчит. А я решил, что у него изначальный файл в xlsm, глядя на картинку  :)  

 

LAD

Пользователь

Сообщений: 22
Регистрация: 20.12.2015

Вы копируете лист со всеми потрохами. Копируйте только то, что Вам нужно. Сделайте новый лист и на него скопируйте диапазон ячеек.

Изменено: LAD07.10.2017 04:58:21

 

RAN

Пользователь

Сообщений: 7091
Регистрация: 21.12.2012

#11

07.10.2017 09:48:49

Цитата
_Igor_61 написал:
   MsgBox «Блин, кажись, получилось…», 64, «ВАУ!»

_Igor_61, Вставьте это в модуль копируемого листа, и вау съедят мыши.

Код
Sub Мяу()
    Dim sfName1$, sfName2$
    Dim sh As Worksheet, nm As Name
    sfName1 = ThisWorkbook.FullName
    sfName1 = Replace(sfName1, "xlsm", "xlsx")
    sfName2 = Left(sfName1, Len(sfName1) - 1)
    Application.ScreenUpdating = False
    Application.CopyObjectsWithCells = False
    Sheets(Array(1, 3)).Copy
    For Each sh In ActiveWorkbook.Worksheets
        sh.UsedRange.Value = sh.UsedRange.Value
    Next
    For Each nm In ActiveWorkbook.Names
        nm.Delete
    Next
    Application.DisplayAlerts = False
    ActiveWorkbook.SaveAs sfName1, 51
    ActiveWorkbook.Close False
    Workbooks.Open sfName1
    ActiveWorkbook.SaveAs sfName2, 56
    ActiveWorkbook.Close False
    Kill sfName1
    Application.DisplayAlerts = True
    Application.CopyObjectsWithCells = True

End Sub

Изменено: RAN07.10.2017 10:51:58

 

_Igor_61

Пользователь

Сообщений: 3007
Регистрация: 18.07.2016

RAN, не, не съедят, еще больше «ВАУ»!   :)
Надеюсь, я тоже когда-то такие задачки буду сходу решать, но пока — изучаю VBA в основном на уровне макрорекордера, т.к. не хватает времени учебники читать. И в Вашем коде многое для меня — темный лес. Например, я не знаю, какую роль выполняет $ в названиях переменных sfName, также не понимаю, как и почему одной и той же переменной (стр.4 и 5) можно присвоить разные значения (или это функции — не знаю), ну и т.д. — короче, мне в этом коде понятны только строки после «Next», и то не все, например, не знаю что значат «51» и «56», ну и т.д. не буду все перечислять, т.к. для каждого моего вопроса придется делать отдельную тему  :)
Ради интереса попробовал поместить Ваш код в файл xls, ошибка 400, новая книга с копируемым листом создается, но код в модуле листа остается.
А ТС пока так и молчит — из какой версии ему в xls нужно сохранять  :)  

 

Юрий М

Модератор

Сообщений: 60570
Регистрация: 14.09.2012

Контакты см. в профиле

$ в имени переменной — это тип (аналог as String). Вот табличка соответствий:
Integer — %
Long — &
Single — !
Doble — #
Currency — @
String — $
По поводу строк 4 и 5: сначала получили путь, а потом в этой строке произвели замену: xlsm заменили на xlsx. В принципе можно было и в одной строке сделать.
51 и 56 — это константы типов файлов.
===
// константы форматов 2003

//  xlCSVWindows = 23;
//  xlDBF2 = 7;
//  xlDBF3 = 8;
//  xlDBF4 = 11;
//  xlDIF = 9;
//  xlExcel9795 = 43;
//  xlTextWindows = 20;
//  xlUnicodeText = 42;
//  xlWebArchive = 45;
//  xlXMLSpreadsheet = 46;
//  xlXMLData = 47;

// основные константы 2007
//  These are the main file formats in Excel 2007-2010:
//  51 = xlOpenXMLWorkbook (without macro’s in 2007-2010, xlsx)
//  52 = xlOpenXMLWorkbookMacroEnabled (with or without macro’s in 2007-2010, xlsm)
//  50 = xlExcel12 (Excel Binary Workbook in 2007-2010 with or without macro’s, xlsb)
//  56 = xlExcel8 (97-2003 format in Excel 2007-2010, xls)

//  57 = PDF
//  60 = xlOpenDocumentSpreadsheet  OpenDocument Spreadsheet

 

_Igor_61

Пользователь

Сообщений: 3007
Регистрация: 18.07.2016

Блин, как же я люблю этот форум! Каждый раз какое-то «ВАУ» для себя нахожу! Юрий М, спасибо большое! Сохранил Ваши пояснения, они очень пригодятся в дальнейшем. Не знал, что части кода можно цифрами задавать (хотя, нет, пример уже знаю —  в MsgBox 64, 32, 48), это, видимо, что-то подобное, если правильно понимаю. Т.е. вместо «xlOpenXMLWorkbook (without macro’s in 2007-2010, xlsx) » пишем «51» и выполняется это действие, так? И я так понимаю, что RAN своим кодом вносит изменения в XML? Дальше — вообще не понимаю — ведь если открыть файл через WinRAR, там же куча папок и файлов XML, т.е. в данном случае через «51» производятся манипуляции с конкретным XML файлом, «51» его находит и выполняет свою задачу?

 

Юрий М

Модератор

Сообщений: 60570
Регистрация: 14.09.2012

Контакты см. в профиле

XML тут нет ) Просто заменяем длинную строку числом )

 

_Igor_61

Пользователь

Сообщений: 3007
Регистрация: 18.07.2016

xlOpenXMLWorkbook — тогда это просто указание на книгу xlsx 2007-2010, этим кодом ее открываем?

 

Юрий М

Модератор

Сообщений: 60570
Регистрация: 14.09.2012

Контакты см. в профиле

Нет, открываем по имени, а это указание ТИПА файла — книга без макросов.

 

_Igor_61

Пользователь

Сообщений: 3007
Регистрация: 18.07.2016

А, кажется понял:  ActiveWorkbook.SaveAs sfName1, 51 — сохраняем активную книгу с заданным именем (sfName1) в xlsx (xlOpenXMLWorkbook (without macro’s in 2007-2010, xlsx) . И равнозначно — можно записать текстом «xlOpenXMLWorkbook (without macro’s in 2007-2010, xlsx», а можно «51».  Я правильно понимаю?
Простите за навязчивость, просто хочу правильно все уяснить для себя, чтобы все правильно понимать и в дальнейшем правильно использовать, если понадобится

 

Николай

Пользователь

Сообщений: 229
Регистрация: 01.01.1970

RAN,
Скопировал

ваш макрос

в личную книгу макросов.
Создал пустой файл Книга1.xlsm с 6 листами.
Открыл его и запустил ваш макрос.
Ошибка. Выделена строка.
ActiveWorkbook.SaveAs sfName1, 51
И табличка.

Что нужно изменить что бы макрос заработал из личной книги макросов. Из листа текущей книги отрабатывает корректно.

Изменено: Николай07.10.2017 19:42:37

 

Юрий М

Модератор

Сообщений: 60570
Регистрация: 14.09.2012

Контакты см. в профиле

 

_Igor_61

Пользователь

Сообщений: 3007
Регистрация: 18.07.2016

 

RAN

Пользователь

Сообщений: 7091
Регистрация: 21.12.2012

sfName1 =

ThisWorkbook

ActiveWorkbook.FullName
……………………………………..
  ActiveWorkbook. Sheets(Array(1, 3)).Copy
  ……………………………

Изменено: RAN07.10.2017 20:30:39

 

RAN

Пользователь

Сообщений: 7091
Регистрация: 21.12.2012

_Igor_61,
F1, Search results for enumeration

 

Николай

Пользователь

Сообщений: 229
Регистрация: 01.01.1970

Кнопка цитирования не для ответа [МОДЕРАТОР]

sfName1 = ActiveWorkbook.FullName
Оказалось достаточно, работает.Но изменил и
ActiveWorkbook. Sheets(Array(1, 3)).Copy
Работает.
Адаптирую под свои нужны отпишу.

 

Николай

Пользователь

Сообщений: 229
Регистрация: 01.01.1970

#25

07.10.2017 21:46:53

На тестовой книге.
Ошибка в строке
ActiveWorkbook.SaveAs sfName1, 51
При этом сохранение новой книги происходит.
Вот код.

Код
Sub кол_вх()
Dim s As String, fldr As String
fldr = "D:111"
s = Dir(fldr & "*.xls")
Do While s <> ""
    With Workbooks.Open(fldr & s)
    Dim sfName1$, sfName2$
    Dim sh As Worksheet, nm As Name
    sfName1 = ActiveWorkbook.FullName
    sfName1 = Replace(sfName1, "xlsm", "xlsx")
    sfName2 = Left(sfName1, Len(sfName1) - 1)
    Application.ScreenUpdating = False
    Application.CopyObjectsWithCells = False
    ActiveWorkbook.Sheets(Array(1, 2, 3, 4)).Copy
    For Each sh In ActiveWorkbook.Worksheets
        sh.UsedRange.Value = sh.UsedRange.Value
    Next
    For Each nm In ActiveWorkbook.Names
        nm.Delete
    Next
    Application.DisplayAlerts = False
    ActiveWorkbook.SaveAs sfName1, 51
    ActiveWorkbook.Close False
    Workbooks.Open sfName1
    ActiveWorkbook.SaveAs sfName2, 56
    ActiveWorkbook.Close False
    Kill sfName1
    Application.DisplayAlerts = True
    Application.CopyObjectsWithCells = True
        .Close 0
    End With
    s = Dir
Loop
End Sub

И скрин ошибки.
Файла  Книга1.xls в каталоге НЕТ.

Прикрепленные файлы

  • 2017-10-07_214428.png (3.53 КБ)

 

Николай

Пользователь

Сообщений: 229
Регистрация: 01.01.1970

#26

07.10.2017 21:49:24

Опа.
Удаление строк

Код
Workbooks.Open sfName1
    ActiveWorkbook.SaveAs sfName2, 56
    ActiveWorkbook.Close False
    Kill sfName1

Решило проблему.

 

Николай

Пользователь

Сообщений: 229
Регистрация: 01.01.1970

#27

08.10.2017 09:51:08

Вот как стал выглядеть код в итоге.

Код
Sub Микро_на_сдачу()
    Dim sFolder As String, sFiles As String
    'диалог запроса выбора папки с файлами
    With Application.FileDialog(msoFileDialogFolderPicker)
        If .Show = False Then Exit Sub
        sFolder = .SelectedItems(1)
    End With
    With UserForm1
        .Show 0
        .Label1.Caption = "Работаем..."
        .Repaint
        For i = 1 To 100000000
        Next
    sFolder = sFolder & IIf(Right(sFolder, 1) = Application.PathSeparator, "", Application.PathSeparator)
    'отключаем обновление экрана, чтобы наши действия не мелькали
    Application.ScreenUpdating = False
    sFiles = Dir(sFolder & "*№*.xlsm")
    Do While sFiles <> ""
        'открываем книгу
        Workbooks.Open sFolder & sFiles
        'действия с файлом         
        Sheets("Приложение № 7 ").Select
        ActiveSheet.Unprotect 'снимаем блокировку с листа
        Cells.Select 'выделяем весь лист
        Selection.Copy 'Копируем
        Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
            :=False, Transpose:=False ' вставляем в лист значения за место формул
        Range("A1").Select
        Sheets("Приложение № 3 ").Select
        ActiveSheet.Unprotect
        Cells.Select
        Selection.Copy
        Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
            :=False, Transpose:=False
        Range("A1").Select
        Sheets("Титульный").Select
        Range("A1").Select
        Sheets("Микроучасток").Select
        Range("Таблица1[[#Headers],[№ п.п]]").Select
        ActiveWindow.Zoom = 100
        'Преорбазуем таблицы в диапазоны
        Dim sh1 As Worksheet
        Dim iObj As ListObject
        For Each sh1 In Worksheets
        For Each iObj In sh1.ListObjects
            iObj.Unlist
        Next
        Next
        'Макрос сохранения книги со старым именем и новым расширением xlsx
        Dim sfName1$
        Dim sh As Worksheet, nm As Name
        sfName1 = ActiveWorkbook.FullName
        sfName1 = Replace(sfName1, "xlsm", "xlsx")
        Application.ScreenUpdating = False
        Application.CopyObjectsWithCells = False
        ActiveWorkbook.Sheets(Array(1, 2, 3, 5)).Copy
        'Преобразование формул в значения, не всегда работает корректно, оставил просто так.
        For Each sh In ActiveWorkbook.Worksheets
            sh.UsedRange.Value = sh.UsedRange.Value
        Next
        'Удаление именнованных диапазонов показать по ctrl+F3
         For Each n In ActiveWorkbook.Names:
        On Error Resume Next
        n.Delete:
        Next
        
        Application.DisplayAlerts = False
        ActiveWorkbook.SaveAs sfName1, 51
        ActiveWorkbook.Close False
        Application.DisplayAlerts = True
        Application.CopyObjectsWithCells = True
    
        'Закрываем книгу с сохранением изменений
        ActiveWorkbook.Close False 'если поставить False - книга будет закрыта без сохранения
        sFiles = Dir
    Loop
    'возвращаем ранее отключенное обновление экрана
    Application.ScreenUpdating = True
    .Label1.Caption = "ГОТОВО"
    End With
End Sub

Огромная благодарность RAN, за его код сохранения файлов.

Изменено: Николай08.10.2017 12:38:36

 

LAD

Пользователь

Сообщений: 22
Регистрация: 20.12.2015

#28

08.10.2017 14:57:17

Не думал, что можно так сильно извратить.

Dear Friends,

This is a very simple yet powerful Excel VBA tip for you. Many a time before sending your workbook with Excel VBA Macro code in it, you want to save your workbook without any VBA code in it.
Therefore here in this article, I will show you – how to save your Excel Workbook without excel macro in it.
This can be done manually as well as using Excel VBA.
At the end of this article, I have a usage example of this VBA method. You can also download a FREE Excel Workbook for you to understand and play around.

Method 1: Manual : Save a Copy of Excel workbook without Macro in it manually

Method 2: VBA: Save a Copy of Excel workbook without Macro using Excel VBA

Download an Excel Workbook to play around [FREE DOWNLOAD]

Manual Method: Save Workbook without Excel Macro

Follow the below steps to save a copy of your workbook as Excel Macro FREE. There will be no excel Macro code in the copy saved.

Step 1:

Go to File Option and Click on Save AS of your xlsm file as shown in the below picture:

Excel Workbook with Excel Macro in it

Excel Workbook with Excel Macro in it

Step 2:

Now save your workbook as xlsx and not as xlsm as shown in the below picture

VBA To SaveAs xlsx

VBA To SaveAs xlsx

Step 3:

On clicking on save, you receive following confirmation popup, once you click on “Yes” then your excel workbook will be saved without Excel Macro code.

Confirmation Popup - Save Excel without Excel Macro Code

Confirmation Popup – Save Excel without Excel Macro Code

Step 4:

Now once you open your .xlsx workbook, you would not see any of the excel macro code as shown in below picture:

Excel Workbook Without Macro

Excel Workbook Without Macro

VBA Method: Save Workbook without Excel Macro using Excel VBA

Now as you have seen how to achieve this manually, I will show you how you can achieve this by using Excel VBA.

Following VBA statement will be able to save your Workbook with Excel Workbook as a Workbook without any Excel VBA code in it.


ThisWorkbook.SaveAs Filename:="C:...abc.xlsx", FileFormat:=xlOpenXMLWorkbook

While executing the above, VBA statement, you will receive the same confirmation popup as shown above – which you get while saving your .xlsm workbook as .xlsx.
This can be annoying in an automated process. To ignore this popup in Excel VBA code, you simply use Application.DisplayAlerts to false before executing the above statement.

Save Excel workbook as Excel Macro FREE Workbook without confirmation Popup

Refer the below VBA code to save your Excel workbook without saving any VBA code in it.


Application.DisplayAlerts = False
ThisWorkbook.SaveAs Filename:="C:...abc.xlsx", FileFormat:=xlOpenXMLWorkbook
Application.DisplayAlerts = True 

Example of usage of above Code

You have an excel workbook which has Excel VBA code inside it to generate a report or to perform any automated task. While sending the copy of that excel workbook, you do not want to send all the code, etc. inside it. In such case you can use above code in order to save the workbook as macro free before attaching to the email.
If you want to know more about it, you can read this article here.

Send current workbook as Macro FREE Workbook as an Attachment in email

Using below code, you can send your current workbook without any VBA code in it which already has VBA codes in it. This is one of the best usage of saving a workbook as Excel Macro FREE Workbook.
Before sending your workbook as an attachment in email, you do not want to share the code along-with the workbook, then this piece of code will do the magic for you.


Sub Email_CurrentWorkBook()

    'Do not forget to change the email ID
    'before running this code

    Dim OlApp As Object
    Dim NewMail As Object
    Dim TempFilePath As String
    Dim fileName As String
    Dim originalWB As Workbook
    Dim tempWB As Workbook
    Dim tempXLSXPath As String
    Dim tempXLSMPath As String

    Set originalWB = ThisWorkbook

    With Application
        .ScreenUpdating = False
        .EnableEvents = False
        .DisplayAlerts = False
    End With

    ' Save your workbook in your temp folder of your system
    ' below code gets the full path of the temporary folder
    ' in your system
    TempFilePath = Environ$("temp") & ""
    fileName = VBA.Left(originalWB.Name, (InStrRev(originalWB.Name, ".", -1, vbTextCompare) - 1))
    fileName = fileName & "-" & Format(Now, "dd-mmm-yy h-mm-ss")
    
    tempXLSMPath = (TempFilePath & fileName & ".xlsm") ' with macro - as is
    tempXLSXPath = (TempFilePath & fileName & ".xlsx") ' without macro

    ' first an as is copy of this workbook is created
    ' and saved as with Macro in it [.xlsm] format
    originalWB.SaveCopyAs (tempXLSMPath)
    
    ' Now open this copy of the current workbook
    ' and saveAs a Macro FREE Workbook [.xlsx] format
    Set tempWB = Workbooks.Open(tempXLSMPath)
    With tempWB
        .SaveAs fileName:=tempXLSXPath, FileFormat:=xlOpenXMLWorkbook
        .Close savechanges:=False
    End With

    ' Now open a new mail
    Set OlApp = CreateObject("Outlook.Application")
    Set NewMail = OlApp.CreateItem(0)

    On Error Resume Next
    With NewMail
        .To = "abc@xyz.com"
        .CC = "abc@xyz.com"
        .BCC = "abc@xyz.com"
        .Subject = "Type your Subject here"
        .Body = "Type the Body of your mail"
        .Attachments.Add tempXLSXPath ' attach .xlsx file
        .Send   'or use .Display to show you the email before sending it.
    End With
    On Error GoTo 0
    
    ' Since mail has been sent with the attachment
    ' Now delete both the temp files
    ' .xlsx and .xlsm
    Kill tempXLSMPath
    Kill tempXLSXPath

    'set nothing to the objects created
    Set NewMail = Nothing
    Set OlApp = Nothing
    Set originalWB = Nothing
    Set tempWB = Nothing

    'Now set the application properties back to true
    With Application
        .ScreenUpdating = True
        .EnableEvents = True
        .DisplayAlerts = True
    End With
End Sub

*************IMPORTANT***********:

In the above code, as you can see, first I have created an exact copy of the current workbook with Macro and then I have saved that copy as a Macro FREE workbook. Strange?? Isn’t it?? Why did not I directly used SaveAs statement to save the current workbook as Macro FREE workbook and then attach it to the email and send?

There is a valid reason for doing so… Before I explain the reason, I would like you to read these two main differences between these two methods…

Difference between SaveAs and SaveCopyAs in Excel VBA

Following are the two main differences between these two methods in Excel VBA…

Difference No: 1 :

After running the SaveAs command, new workbook becomes the current Workbook [in VBA terms – ThisWorkbook]. In other words, after running the SaveAs command, your original workbook will no longer remain opened and accessible [unless you open the original workbook again by providing the Workbooks.Open command].

While SaveCopyAs does it exactly opposite. Here original workbook remains open and copy is made as-it-is with the given file name and path.

This is the reason… why I could not directly use this SaveAs method to save a macro free copy of the current workbook where actually my code is running. So as soon as Save As command is run, then in the current workbook there is no macro any more and code will stop running there and further statements will not be executed any more.

Difference No: 2 :

Using SaveAs you can change many things around your Excel Workbook.. like
1. Secure it by providing a password
2. Change the FileName, FilePath, FileFormat, FileType etc.
any more…

While using SaveCopyAs, all you can do is just change the FileName or FilePath or both. Other than this, you can not make any changes in the workbook. It is simply an AS-IS copy of your workbook.

This is the reason… why I could not just use SaveCopyAs method. By using this method, I can not change for FileFormat of the Workbook as Macro FREE (.xlsx).

Now you understand, why a combination of these two methods was required in order to achieve this scenario of sending a Macro FREE copy of current Excel Workbook as an attachment in an email.

  • #2

have a read here > https://www.rondebruin.nl/win/s5/win001.htm bearing in mind you want to change the workbook to one without macros that is currently running a macro, or you could use the routine to just save the woeksheet itself as the xlsx

  • #3

Dear Mole999,

Thanks very much for your prompt and kind response to my Post.

I must confess that my knowledge of vba is still very basic. I got through to the link that you provided.

Unfortunately, due to my very basic knowledge, the options provided got me confused, hence I ask for your further kind help or that of any other forum member.

A kind friend provided me with the code in my Post #1 above. The code works OK to use it for saving as a PDF. However, there is need now to discontinue saving as PDF but as a normal Excel file without macros. I need it to complete a task that I currently have.

I should therefore be grateful if the code in my Post #1 can be tweaked or adjusted to meet that need. If saving the Excel worksheet as a normal Excel file (without macros) would require a code that is completely different altogether from that which I have shown in my Post #1 , I’d appreciate help with that, please. I wish I knew which of the options listed in the rondebruin link to choose that would meet my need.

I look forward to further help with this, please.

Thanks.

Kenny

Last edited: Dec 24, 2017

Fluff

Fluff

MrExcel MVP, Moderator


  • #4

Untested, but try

Code:

' 1 Newly created file is saved as a PDF file
Path = "C:Copy Invoices"
 
ActiveWorkbook.SaveAs FileName:=Path & "" & sNewWorkbookName & " - " & [G5], FileFormat:=51

  • #5

Thanks Fluff for your kindness and for your very helpful code.

Although it saved the worksheet as a macro-free Excel file, there are two problems, about which I need your help:

1. The main Invoice Sheet has the following command buttons — ‘Save & Clear’; ‘Exit‘. Although the main Invoice form and details cover A1 to N52, the above command buttons reside in columns O to R.

And when I click on the ‘Save & Clear’ command button, and it eventually saves the worksheet, I find that the saved copy contains those two command buttons.

I would like it to save the worksheet, but without the command buttons appearing on the saved copies, please.

2. When I click on the ‘Save & Clear’ command button, I get a message box with the following message:

The following features cannot be saved in macro-free workbook: .VB Project.
To save a file with these features, click No and then choose a macro-enabled file type in the file type list.
To continue saving as a macro-free workbook, click Yes
.’

I have to click Yes for it to save as macro-free. Please is there any adjustment that can be made to your code to prevent above message and get it to save straightaway the copy as a macro-free fille?

Apart from these two issues, every thing else is fine, and I am grateful to you for your help.

Thanks very much.

Kenny

Fluff

Fluff

MrExcel MVP, Moderator


  • #6

Try

Code:

   Dim Shp As Shape
   Dim Pth As String
   
   For Each Shp In ActiveSheet.Shapes
      Shp.Delete
   Next Shp
   
   Pth = "C:Copy Invoices"
   Application.DisplayAlerts = False
   ActiveWorkbook.SaveAs FileName:=Pth & "" & sNewWorkbookName & " - " & [G5], FileFormat:=51
   Application.DisplayAlerts = True

  • #7

Dear Fluff,

Thanks for your continued support.

The corrected code (ref your post #6 ) almost did the job except for some minor issue.

Meanwhile, I am sorry that I did not inform you that the body of the Invoice Sheet contains some Option buttons which have to be selected while completing the Invoice. These option buttons are required as part of the Invoice.

Therefore, what happens is that the following line of your code deletes all the ‘command buttons’ includiang the ‘option buttons’ in the body of the Invoice:

Code:

For Each Shp In ActiveSheet.Shapes
      Shp.Delete
   Next Shp

In the course of saving the worksheet as a macro-free file, I would like the code to exclude/delete the command buttons, but not the option buttons in the body of the Invoice. I believe that the word ‘Shapes’ in the code covers both the command buttons and option buttons. Please, is there anything that can be done to delete only the command buttons and not the option buttons in the body of the Invoice?

I have no doubt that this final tweak will completely solve my problem.

Again, thanks for all your help.

Kenny

Last edited: Dec 25, 2017

Fluff

Fluff

MrExcel MVP, Moderator


  • #8

How about

Code:

Private Sub CommandButton1_Click()
'Ron de Bruin https://www.rondebruin.nl/win/s4/win002.htm

   Dim obj As OLEObject
   Dim Pth As String
   
   For Each obj In ActiveSheet.OLEObjects
      If TypeOf obj.Object Is MSForms.CommandButton Then
         obj.Delete
      End If
   Next
   
   Pth = "C:Copy Invoices"
   Application.DisplayAlerts = False
   ActiveWorkbook.SaveAs FileName:=Pth & "" & sNewWorkbookName & " - " & [G5], FileFormat:=51
   Application.DisplayAlerts = True
End Sub

  • #9

Dear Fluff,

I am very sorry for bothering you this much with this problem which appears to be somewhat knotty. I have tried your code but can’t seem to get it it to work. The code does not get rid of, from the saved copies, the buttons that control the macros.

I must add that your code, in your Post #6 above as follows:

Code:

Dim Shp As Shape
   Dim Pth As String
  
   For Each Shp In ActiveSheet.Shapes
      Shp.Delete
   Next Shp

which refers to the buttons as ‘shapes’ successfully got rid of the shapes which control the macros, and which serve, for me, as command buttons. The only unfortunate thing is that in doing so, it also got rid of the option buttons, which should be allowed to remain.

I created those ‘command buttons’ using the ‘Insert Shapes’ feature in my Excel 2007. The shapes look more elegant than either the ‘Form’ or ‘ActiveX’ command buttons.

Unfortunately, your most recent code (Post #8 ) does not delete any of the command buttons (whether created with shapes or with Form or ActiveX) from the saved copies.

As I searched some other forum, I came across a thread by someone who had a somewhat similar issue — although not completely the same as mine. The member indicated that he solved his own problem with the following vba code:

Code:

[B]'Delete the command button in new workbook[/B]
[B]With ActiveSheet[/B]
[B]    .Shapes("CBONew").Delete[/B]
[B]    .Shapes("CBOSave").Delete[/B]
[B]End With[/B]

I assume that the two buttons he has that control the macros are named ‘New’ and ‘Save’, respectively.

The two shapes that I have (which control macros, and which I want deleted from the saved copies of the Invoice) are named ‘SAVE’ and ‘EXIT’, respectively.

I tried to replicate his code — inserting the names of my own two shapes. But I keep getting ‘Runtime Errors’.

I wish to retain the two beautiful shapes and having them serve as command buttons, and wish that there is a way your code (Post #6 ) could be tweaked to do the trick for me — or indeed any other code that can do it.

The whole thing is not only frustrating me, but I seem to be letting you share in my frustration — even at Christmas! Please, I sincerely apologize for the bother.

I remain eternally grateful to you for your continued help.

Kenny

Last edited: Dec 25, 2017

Fluff

Fluff

MrExcel MVP, Moderator


  • #10

Try

Code:

Sub RemoveShapes()
   Dim Shp As Shape
   Dim Pth As String
   
   For Each Shp In ActiveSheet.Shapes
      If Not (Shp.Type = msoOLEControlObject Or Shp.Type = msoFormControl) Then Shp.Delete
   Next Shp

   Pth = "C:Copy Invoices"
   Application.DisplayAlerts = False
   ActiveWorkbook.SaveAs FileName:=Pth & "" & sNewWorkbookName & " - " & [G5], FileFormat:=51
   Application.DisplayAlerts = True
End Sub

You will need to set a reference.
In the VBE select tools > References > Microsoft Office xx.0 Object Library (make sure you check the box, rather than just select the line) > OK

INTELLIGENT WORK FORUMS
FOR COMPUTER PROFESSIONALS

Contact US

Thanks. We have received your request and will respond promptly.

Log In

Come Join Us!

Are you a
Computer / IT professional?
Join Tek-Tips Forums!

  • Talk With Other Members
  • Be Notified Of Responses
    To Your Posts
  • Keyword Search
  • One-Click Access To Your
    Favorite Forums
  • Automated Signatures
    On Your Posts
  • Best Of All, It’s Free!

*Tek-Tips’s functionality depends on members receiving e-mail. By joining you are opting in to receive e-mail.

Posting Guidelines

Promoting, selling, recruiting, coursework and thesis posting is forbidden.

Students Click Here

Save Excel without macros?

Save Excel without macros?

(OP)

24 Aug 04 11:26

I’d like to save a workbook via vba without saving the macros using the following code:-

 ActiveWorkbook.SaveAs FileName:=Name, FileFormat:= _
        xlNormal, Password:=»», WriteResPassword:=»», ReadOnlyRecommended:=False _
        , CreateBackup:=False

If this is not possible, is it possible to disable the macro’s when the new saved document is opened?

CodMan

Red Flag Submitted

Thank you for helping keep Tek-Tips Forums free from inappropriate posts.
The Tek-Tips staff will check this out and take appropriate action.

Join Tek-Tips® Today!

Join your peers on the Internet’s largest technical computer professional community.
It’s easy to join and it’s free.

Here’s Why Members Love Tek-Tips Forums:

  • Tek-Tips ForumsTalk To Other Members
  • Notification Of Responses To Questions
  • Favorite Forums One Click Access
  • Keyword Search Of All Posts, And More…

Register now while it’s still free!

Already a member? Close this window and log in.

Join Us             Close

Сохранить файл без макросов

pips

Дата: Вторник, 06.11.2018, 16:10 |
Сообщение № 1

Группа: Пользователи

Ранг: Участник

Сообщений: 69


Репутация:

0

±

Замечаний:
0% ±


Excel 2010

Прошу не кидать тапками, то, что нашел на форуме, не смог применить для своей ситуации.
Есть код, сохраняющий файл в заранее выбранную папку. Но, так как файл потихоньку обрастает кодом, размеры сохранений занимают довольно много места на диске.
Подскажите, пожалуйста, можно ли переписать код таким образом, чтобы конечный файл сохранялся в формате Excel без макросов? (.xls или .xlsx)

[vba]

Код

Private Sub CommandButton18_Click() ‘сохранение в нужную папку
    Dim FileName$, NewDir$
    ‘создание папки в текущей папке и сохранение туда файла
    ‘NewDir = ThisWorkbook.Path & «» & Replace_symbols(UserForm1.TextBox8.Text) & Replace_symbols(UserForm1.ComboBox1.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text)
    ‘создание папки в нужной директории
    NewDir = Worksheets(«Service»).Range(«B2») & «» & Replace_symbols(UserForm1.TextBox8.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text)
    If Dir(NewDir, vbDirectory) = «» Then
    MkDir (NewDir)
    FileName = NewDir & «» & Replace_symbols(UserForm1.TextBox8.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text) & «.xlsm»
    ActiveWorkbook.SaveCopyAs FileName
    MsgBox «Файл сохранен в папке Отчеты»
    Else
    SavePath = SaveFolder(NewDir)
    FileName = Replace_symbols(UserForm1.TextBox8.Text) & Replace_symbols(UserForm1.ComboBox1.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text) & «.xlsm»
    ActiveWorkbook.SaveCopyAs SavePath & «» & FileName
    MsgBox «Такая папка уже существует. Копия сохранена в папке Отчеты»
    End If
End Sub

[/vba]
Спасибо!

Сообщение отредактировал pipsВторник, 06.11.2018, 16:11

 

Ответить

sboy

Дата: Вторник, 06.11.2018, 16:14 |
Сообщение № 2

Группа: Друзья

Ранг: Участник клуба

Сообщений: 2566


Репутация:

724

±

Замечаний:
0% ±


Excel 2010

Поменяйте расширение в коде с .xslm на .xlsx и не забудьте отключить оповещения в начале кода и включить в конце
[vba]

Код

Application.DisplayAlerts = False ‘True

[/vba]


Яндекс: 410016850021169

 

Ответить

_Boroda_

Дата: Вторник, 06.11.2018, 16:16 |
Сообщение № 3

Группа: Модераторы

Ранг: Местный житель

Сообщений: 16618


Репутация:

6465

±

Замечаний:
0% ±


2003; 2007; 2010; 2013 RUS

чтобы конечный файл сохранялся в формате Excel без макросов? (.xls или .xlsx)

А какая разница? На размер повлияет только в большую сторону (если xls). Меньше будет, если сохранять в xlsb
Не пробовали заменить xlsm на xlsx в коде?


Скажи мне, кудесник, любимец ба’гов…
Платная помощь:
Boroda_Excel@mail.ru
Яндекс-деньги: 41001632713405 | Webmoney: R289877159277; Z102172301748; E177867141995

 

Ответить

pips

Дата: Вторник, 06.11.2018, 16:19 |
Сообщение № 4

Группа: Пользователи

Ранг: Участник

Сообщений: 69


Репутация:

0

±

Замечаний:
0% ±


Excel 2010

Я, возможно, как то не так объяснил. Я менял расширение при сохранении на .xls, при открытии готового файла было предупреждение, что расширение файла не соотвтетствует его формату, и все макросы и UserForm были в файле сохранены. После предупреждения файл открылся.
При замене на .xlsx появляется ошибка, но файл открыть не возможно.

Сообщение отредактировал pipsВторник, 06.11.2018, 16:29

 

Ответить

_Boroda_

Дата: Вторник, 06.11.2018, 16:33 |
Сообщение № 5

Группа: Модераторы

Ранг: Местный житель

Сообщений: 16618


Репутация:

6465

±

Замечаний:
0% ±


2003; 2007; 2010; 2013 RUS

У Вас получается, что Вы хотите сохранить КОПИЮ, которая копийе не является — расширения-то разные. Тогда сначала сохраняйте в xlsm, потом открывайте копию и пересохраняйте в нужном формате. Все это, конечно же, макросом

Примерно вот так
[vba]

Код

With Workbooks.Open(NewDir & «» & FileName)
      .SaveAs Replace(NewDir & «» & FileName, «.xlsm», «.xlsb»)
      .Close 0
End With
Kill NewDir & «» & FileName

[/vba]


Скажи мне, кудесник, любимец ба’гов…
Платная помощь:
Boroda_Excel@mail.ru
Яндекс-деньги: 41001632713405 | Webmoney: R289877159277; Z102172301748; E177867141995

 

Ответить

pips

Дата: Вторник, 06.11.2018, 16:35 |
Сообщение № 6

Группа: Пользователи

Ранг: Участник

Сообщений: 69


Репутация:

0

±

Замечаний:
0% ±


Excel 2010

Понял, большое спасибо за код.

Сообщение отредактировал pipsВторник, 06.11.2018, 16:40

 

Ответить

pips

Дата: Среда, 07.11.2018, 09:54 |
Сообщение № 7

Группа: Пользователи

Ранг: Участник

Сообщений: 69


Репутация:

0

±

Замечаний:
0% ±


Excel 2010

В код добавил эти строчки

[vba]

Код

    ActiveWorkbook.SaveCopyAs FileName
        With Workbooks.Open(FileName)
        .SaveAs Replace(FileName, «.xlsm», «.xlsb»)
        .Close 0
        End With
    Kill FileName

[/vba]

В таком виде он не работает, ошибка в строке .SaveAs…….
При замене .xlsb на .xls файл сохраняется, но при открытии все равно выскакивает сообщение «Файл Name.xls не соответствует разрешению файла. Возможно, файл поврежден или небезопасен»
В итоге открывается файл с сохранением кода VBA…

 

Ответить

_Boroda_

Дата: Среда, 07.11.2018, 10:00 |
Сообщение № 8

Группа: Модераторы

Ранг: Местный житель

Сообщений: 16618


Репутация:

6465

±

Замечаний:
0% ±


2003; 2007; 2010; 2013 RUS

Весь код покажите


Скажи мне, кудесник, любимец ба’гов…
Платная помощь:
Boroda_Excel@mail.ru
Яндекс-деньги: 41001632713405 | Webmoney: R289877159277; Z102172301748; E177867141995

 

Ответить

pips

Дата: Среда, 07.11.2018, 10:02 |
Сообщение № 9

Группа: Пользователи

Ранг: Участник

Сообщений: 69


Репутация:

0

±

Замечаний:
0% ±


Excel 2010

[vba]

Код

Private Sub CommandButton18_Click() ‘сохранение в нужную папку
    Dim FileName$, NewDir$
    ‘создание папки в текущей папке и сохранение туда файла
    ‘NewDir = ThisWorkbook.Path & «» & Replace_symbols(UserForm1.TextBox8.Text) & Replace_symbols(UserForm1.ComboBox1.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text)
    ‘создание папки в нужной директории
    NewDir = Worksheets(«Service»).Range(«B2») & «» & Replace_symbols(UserForm1.TextBox8.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text)
    If Dir(NewDir, vbDirectory) = «» Then
    MkDir (NewDir)
    FileName = NewDir & «» & Replace_symbols(UserForm1.TextBox8.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text) & «.xlsm»
    ActiveWorkbook.SaveCopyAs FileName
    With Workbooks.Open(FileName)
        .SaveAs Replace(FileName, «.xlsm», «.xlsb»)
        .Close 0
        End With
    Kill FileName
    MsgBox «Файл сохранен в папке Отчеты»
    Else
    SavePath = SaveFolder(NewDir)
    FileName = Replace_symbols(UserForm1.TextBox8.Text) & Replace_symbols(UserForm1.ComboBox1.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text) & «.xlsm»
    ActiveWorkbook.SaveCopyAs SavePath & «» & FileName
    MsgBox «Такая папка уже существует. Копия сохранена в папке Отчеты»
    End If

    End Sub

[/vba]

Сообщение отредактировал pipsСреда, 07.11.2018, 10:03

 

Ответить

_Boroda_

Дата: Среда, 07.11.2018, 10:24 |
Сообщение № 10

Группа: Модераторы

Ранг: Местный житель

Сообщений: 16618


Репутация:

6465

±

Замечаний:
0% ±


2003; 2007; 2010; 2013 RUS


Скажи мне, кудесник, любимец ба’гов…
Платная помощь:
Boroda_Excel@mail.ru
Яндекс-деньги: 41001632713405 | Webmoney: R289877159277; Z102172301748; E177867141995

 

Ответить

pips

Дата: Среда, 07.11.2018, 10:25 |
Сообщение № 11

Группа: Пользователи

Ранг: Участник

Сообщений: 69


Репутация:

0

±

Замечаний:
0% ±


Excel 2010

Хорошо, спасибо. Когда что то получится, отпишусь.

 

Ответить

RAN

Дата: Среда, 07.11.2018, 12:15 |
Сообщение № 12

Группа: Друзья

Ранг: Экселист

Сообщений: 5645

pips‘у от Пипса
[vba]

Код

    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    Dim thisName As String
    thisName = ThisWorkbook.FullName
    ThisWorkbook.Save
    ThisWorkbook.SaveAs sSavePath & «ВВОД_» & sSaveBaseName & «.xlsx», 51
    Workbooks.Open thisName
    ThisWorkbook.Close False
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True

[/vba]


Быть или не быть, вот в чем загвоздка!

 

Ответить

pips

Дата: Среда, 07.11.2018, 12:17 |
Сообщение № 13

Группа: Пользователи

Ранг: Участник

Сообщений: 69


Репутация:

0

±

Замечаний:
0% ±


Excel 2010

большое спасибо за помощь, вот что в итоге получилось. Приведу полный код.

[vba]

Код

Private Sub CommandButton18_Click() ‘сохранение в нужную папку
    Dim FileName$, NewDir$
    ‘создание папки в текущей папке и сохранение туда файла
    ‘NewDir = ThisWorkbook.Path & «» & Replace_symbols(UserForm1.TextBox8.Text) & Replace_symbols(UserForm1.ComboBox1.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text)
    ‘создание папки в нужной директории
    NewDir = Worksheets(«Service»).Range(«B2») & «» & Replace_symbols(UserForm1.TextBox8.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text)
    If Dir(NewDir, vbDirectory) = «» Then
    MkDir (NewDir)
    FileName = NewDir & «» & Replace_symbols(UserForm1.TextBox8.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text) ‘1) убрал отсюда расширение
    ActiveWorkbook.SaveCopyAs FileName & «.xlsm»   ‘2)вставил его сюда
    Application.DisplayAlerts = False   ‘3) это чтобы не спрашивал, сохранять ли в формате без макросов
    With Workbooks.Open(FileName)
        .SaveAs FileName, xlWorkbookDefault   ‘4) заменил на XlFileFormat
        .Close 0
        End With
    Application.DisplayAlerts = True
    Kill FileName & «.xlsm»                 ‘5) профит
    MsgBox «Файл сохранен в папке Отчеты»
    Else
    SavePath = SaveFolder(NewDir)
    FileName = Replace_symbols(UserForm1.TextBox8.Text) & Replace_symbols(UserForm1.ComboBox1.Text) & «_» & Replace_symbols(UserForm1.TextBox4.Text)
    ActiveWorkbook.SaveCopyAs SavePath & «» & FileName & «.xlsm»
        Application.DisplayAlerts = False
    With Workbooks.Open(SavePath & «» & FileName & «.xlsm»)
        .SaveAs SavePath & «» & FileName, xlWorkbookDefault
        .Close 0
        End With
        Application.DisplayAlerts = True
    Kill SavePath & «» & FileName & «.xlsm»
    MsgBox «Такая папка уже существует. Копия сохранена в папке Отчеты»
    End If

End Sub

[/vba]

 

Ответить

pips

Дата: Среда, 07.11.2018, 12:18 |
Сообщение № 14

Группа: Пользователи

Ранг: Участник

Сообщений: 69


Репутация:

0

±

Замечаний:
0% ±


Excel 2010

Коту привет :D Спасибо, потестирую)

 

Ответить

pips

Дата: Среда, 07.11.2018, 12:45 |
Сообщение № 15

Группа: Пользователи

Ранг: Участник

Сообщений: 69


Репутация:

0

±

Замечаний:
0% ±


Excel 2010

RAN, спасибо, так намного проще ^_^

 

Ответить

Like this post? Please share to your friends:
  • Excel vba rows xldown
  • Excel vba rows to columns excel
  • Excel vba row object
  • Excel vba return without gosub
  • Excel vba rest api