Домашняя страница Undo Do New Save Карта сайта Обратная связь Поиск по форуму
МИР MS EXCEL - Гость.xls

Вход

Регистрация

Напомнить пароль

 

= Мир MS Excel/Резервное копирование в excel - Мир MS Excel

Регистрация · Логин: · Пароль: · · Забыли пароль?
Страница 1 из 11
Модератор форума: _Boroda_, Pelena, Manyasha, SLAVICK 
Мир MS Excel » Вопросы и решения » Вопросы по VBA » Резервное копирование в excel (Макросы/Sub)
Резервное копирование в excel
Killerlord Дата: Понедельник, 29.02.2016, 17:58 | Сообщение № 1
Группа: Пользователи
Ранг: Новичок
Сообщений: 20
Репутация: 0 ±
Замечаний: 80% ±

Excel 2007
Здравствуйте, мне нужно сделать чтоб при сохранении создавалась резервная копия документа excel.
На форуме нашел макрос но он сделан для Word(a)
[vba]
Код


Private Sub WordApp_DocumentBeforeSave(ByVal Doc As Document, SaveAsUI As Boolean, Cancel As Boolean)
    Dim NewName$, Suffix$, i&
    NewName = Doc.Name
    If NewName <> Me.Name Then Exit Sub
    i = InStrRev(NewName, ".")
    Suffix = " (ResCopy " & Format(Now, "dd.mm.yyyy hh-mm-ss)")
    If i Then _
        NewName = Left$(NewName, i - 1) & Suffix & Mid$(NewName, i) Else _
        NewName = NewName & Suffix
    Doc.SaveAs "D:\СПД Граб\" & NewName
End Sub
[/vba]
Я проверил для ворда он работает хорошо. Как сделать то же самое только для Excel ?
 
Ответить
СообщениеЗдравствуйте, мне нужно сделать чтоб при сохранении создавалась резервная копия документа excel.
На форуме нашел макрос но он сделан для Word(a)
[vba]
Код


Private Sub WordApp_DocumentBeforeSave(ByVal Doc As Document, SaveAsUI As Boolean, Cancel As Boolean)
    Dim NewName$, Suffix$, i&
    NewName = Doc.Name
    If NewName <> Me.Name Then Exit Sub
    i = InStrRev(NewName, ".")
    Suffix = " (ResCopy " & Format(Now, "dd.mm.yyyy hh-mm-ss)")
    If i Then _
        NewName = Left$(NewName, i - 1) & Suffix & Mid$(NewName, i) Else _
        NewName = NewName & Suffix
    Doc.SaveAs "D:\СПД Граб\" & NewName
End Sub
[/vba]
Я проверил для ворда он работает хорошо. Как сделать то же самое только для Excel ?

Автор - Killerlord
Дата добавления - 29.02.2016 в 17:58
Manyasha Дата: Понедельник, 29.02.2016, 18:12 | Сообщение № 2
Группа: Модераторы
Ранг: Старожил
Сообщений: 1590
Репутация: 669 ±
Замечаний: 0% ±

Excel 2007, 2010
Killerlord, так попробуйте:
[vba]
Код
Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean)
    Dim NewName$, Suffix$, i&
    NewName = ThisWorkbook.Name
    i = InStrRev(NewName, ".")
    Suffix = " (ResCopy " & Format(Now, "dd.mm.yyyy hh-mm-ss)")
    If i Then _
        NewName = Left$(NewName, i - 1) & Suffix & Mid$(NewName, i) Else _
        NewName = NewName & Suffix
    ThisWorkbook.SaveCopyAs "D:\СПД Граб\" & NewName
End Sub
[/vba]
код скопируйте в модуль книги


marinamorozova_box@mail.ru
ЯД: 410013299366744 WM: R193491431804
 
Ответить
СообщениеKillerlord, так попробуйте:
[vba]
Код
Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean)
    Dim NewName$, Suffix$, i&
    NewName = ThisWorkbook.Name
    i = InStrRev(NewName, ".")
    Suffix = " (ResCopy " & Format(Now, "dd.mm.yyyy hh-mm-ss)")
    If i Then _
        NewName = Left$(NewName, i - 1) & Suffix & Mid$(NewName, i) Else _
        NewName = NewName & Suffix
    ThisWorkbook.SaveCopyAs "D:\СПД Граб\" & NewName
End Sub
[/vba]
код скопируйте в модуль книги

Автор - Manyasha
Дата добавления - 29.02.2016 в 18:12
Killerlord Дата: Понедельник, 29.02.2016, 18:37 | Сообщение № 3
Группа: Пользователи
Ранг: Новичок
Сообщений: 20
Репутация: 0 ±
Замечаний: 80% ±

Excel 2007
удалено
Спасибо большое, все работает.
[moder]Не надо цитировать посты целиком - это нарушение правил форума![/moder]


Сообщение отредактировал Manyasha - Понедельник, 29.02.2016, 18:47
 
Ответить
Сообщениеудалено
Спасибо большое, все работает.
[moder]Не надо цитировать посты целиком - это нарушение правил форума![/moder]

Автор - Killerlord
Дата добавления - 29.02.2016 в 18:37
Мир MS Excel » Вопросы и решения » Вопросы по VBA » Резервное копирование в excel (Макросы/Sub)
Страница 1 из 11
Поиск:

Яндекс цитирования
© 2010-2016 · Дизайн: MichaelCH · Хостинг от uCoz · При использовании материалов сайта, ссылка на www.excelworld.ru обязательна!