Создание файлов Excel методами Workbooks.Add, Worksheet.Copy и текстовых файлов с помощью оператора Open и метода CreateTextFile из кода VBA Excel. Создание документов Word рассмотрено в отдельной статье.
Метод Workbooks.Add
Описание
Файлы Excel можно создавать из кода VBA с помощью метода Add объекта Workbooks.
Workbooks.Add – это метод, который создает и возвращает новую книгу Excel. Новая книга после создания становится активной.
Ссылку на новую книгу Excel, созданную методом Workbooks.Add, можно присвоить объектной переменной с помощью оператора Set
или обращаться к ней, как к активной книге: ActiveWorkbook
.
Синтаксис
Workbooks.Add (Template)
Template – параметр, который определяет, как создается новая книга.
Значение Template | Параметры новой книги |
---|---|
Отсутствует | Новая книга с количеством листов по умолчанию. |
Полное имя существующего файла Excel | Новая книга с указанным файлом в качестве шаблона. |
xlWBATChart | Новый файл с одним листом диаграммы. |
xlWBATWorksheet | Новый файл с одним рабочим листом. |
Примеры
Пример 1
Создание новой книги Excel с количеством листов по умолчанию и сохранение ее в папку, где расположен файл с кодом VBA:
Sub Primer1() ‘Создаем новую книгу Workbooks.Add ‘Сохраняем книгу в папку, где расположен файл с кодом ActiveWorkbook.SaveAs (ThisWorkbook.Path & «Моя новая книга.xlsx») ‘Закрываем файл ActiveWorkbook.Close End Sub |
Файл «Моя новая книга.xlsx» понадобится для следующего примера.
Пример 2
Создание новой книги по файлу «Моя новая книга.xlsx» в качестве шаблона с присвоением ссылки на нее объектной переменной, сохранение нового файла с новым именем и добавление в него нового рабочего листа:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
Sub Primer2() ‘Объявляем объектную переменную с ранней привязкой Dim MyWorkbook As Workbook ‘Создаем новую книгу по шаблону файла «Моя новая книга.xlsx» Set MyWorkbook = Workbooks.Add(ThisWorkbook.Path & «Моя новая книга.xlsx») With MyWorkbook ‘Смотрим какое имя присвоено новому файлу по умолчанию MsgBox .Name ‘»Моя новая книга1″ ‘Сохраняем книгу с новым именем .SaveAs (ThisWorkbook.Path & «Моя самая новая книга.xlsx») ‘Смотрим новое имя файла MsgBox .Name ‘»Моя самая новая книга» ‘Добавляем в книгу новый лист с именем «Мой новый лист» .Sheets.Add.Name = «Мой новый лист» ‘Сохраняем файл .Save End With End Sub |
Метод Worksheet.Copy
Описание
Если в коде VBA Excel применить метод Worksheet.Copy без указания параметра Before или After, будет создана новая книга с копируемым листом (листами). Новая книга станет активной.
Примеры
Пример 3
Создание новой книги с помощью копирования одного листа (в этом примере используется книга, созданная в первом примере):
Sub Primer3() ‘Если книга источник не открыта, ее нужно открыть Workbooks.Open (ThisWorkbook.Path & «Моя новая книга.xlsx») ‘Создаем новую книгу копированием одного листа Workbooks(«Моя новая книга.xlsx»).Worksheets(«Лист1»).Copy ‘Сохраняем новую книгу с именем «Еще одна книжица.xlsx» в папку, ‘где расположен файл с кодом ActiveWorkbook.SaveAs (ThisWorkbook.Path & «Еще одна книжица.xlsx») End Sub |
Также, как и при создании нового файла Excel методом Workbooks.Add, при создании новой книги методом Worksheet.Copy, можно ссылку на нее присвоить объектной переменной.
Пример 4
Создание новой книги, в которую включены копии всех рабочих листов из файла с кодом VBA:
Sub Primer4() ThisWorkbook.Worksheets.Copy End Sub |
Пример 5
Создание новой книги, в которую включены копии выбранных рабочих листов из файла с кодом VBA:
Sub Primer5() ThisWorkbook.Sheets(Array(«Лист1», «Лист3», «Лист7»)).Copy End Sub |
Создание текстовых файлов
Оператор Open
При попытке открыть несуществующий текстовый файл с помощью оператора Open, такой файл будет создан. Новый файл будет создан при открытии его в любом режиме последовательного доступа, кроме Input (только для чтения).
Пример
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
Sub Primer6() Dim ff As Integer, ws As Object ‘Получаем свободный номер для открываемого файла ff = FreeFile ‘Создаем новый текстовый файл путем открытия ‘несуществующего в режиме чтения и записи Open ThisWorkbook.Path & «Мой-новый-файл.txt» For Output As ff ‘Записываем в файл текст Write #ff, «Этот файл создан при его открытии оператором « & _ «Open по несуществующему адресу (полному имени).» ‘Закрываем файл Close ff ‘Открываем файл для просмотра Set ws = CreateObject(«WScript.Shell») ws.Run ThisWorkbook.Path & «Мой-новый-файл.txt» Set ws = Nothing End Sub |
В имени текстового файла пробелы заменены дефисами (знаками минус), так как метод Run объекта Wscript.Shell не способен открывать файлы с именами, содержащими пробелы.
Рекомендую открывать файлы для просмотра методом ThisWorkbook.FollowHyperlink. Пример и преимущества этого метода в статье VBA Excel. Открыть файл другой программы.
Метод FileSystemObject.CreateTextFile
Для создания нового текстового файла из кода VBA Excel по указанному имени, можно использовать метод CreateTextFile объекта FileSystemObject.
Пример
Sub Primer7() Dim fso, fl, ws ‘Создаем новый экземпляр объекта FileSystemObject Set fso = CreateObject(«Scripting.FileSystemObject») ‘Присваиваем переменной fl новый объект TextStream, ‘связанный с созданным и открытым для записи файлом Set fl = fso.CreateTextFile(ThisWorkbook.Path & «Еще-один-текстовый-файл.txt») ‘Записываем в файл текст fl.Write («Этот текстовый файл создан методом CreateTextFile объекта FileSystemObject.») ‘Закрываем файл fl.Close ‘Открываем файл для просмотра Set ws = CreateObject(«WScript.Shell») ws.Run ThisWorkbook.Path & «Еще-один-текстовый-файл.txt» End Sub |
Стоит отметить, что новый текстовый файл может быть создан и с помощью метода OpenTextFile объекта FileSystemObject при условии присвоения параметру create значения True.
Создание книги с одним листом
В процессе работы иногда возникает необходимость создания рабочей книги, состоящей только из одного листа. Можно, конечно, создать обычную новую книгу и вручную удалить ненужные листы (напомню, что для удаления необходимо щелкнуть правой кнопкой мыши на ярлыке с именем листа и выбрать в контекстном меню пункт Удалить). Однако для решения данной задачи все же целесообразнее воспользоваться языком VBA и написать макрос, код которого приведен в листинге 2.3.
Листинг 2.3. Книга с одним листом
Sub NewOneSheetBook()
Workbooks.Add xlWBATWorksheet
End Sub
В результате выполнения данного макроса будет создана новая рабочая книга, в состав которой войдет только один рабочий лист. Эта книга будет открыта в отдельном окне.
как создать книгу с одним листом строка у меня выглядет так Set CFOBook = Workbooks.Add, но создаеться 3 листа в книге |
|
удалить лишние |
|
Sub NewBook() End Sub |
|
ikki Пользователь Сообщений: 9709 |
из секретных архивов: Add method as it applies to the Workbooks object. Creates a new workbook. The new workbook becomes the active workbook. Returns a Workbook object. expression.Add(Template) expression Required. An expression that returns a Workbooks object. Template Optional Variant. Determines how the new workbook is created. If this argument is a string specifying the name of an existing Microsoft Excel file, the new workbook is created with the specified file as a template. If this argument is a constant, the new workbook contains a single sheet of the specified type. Can be one of the following XlWBATemplate constants: xlWBATChart, xlWBATExcel4IntlMacroSheet, xlWBATExcel4MacroSheet, or xlWBATWorksheet. If this argument is omitted, Microsoft Excel creates a new workbook with a number of blank sheets (the number of sheets is set by the SheetsInNewWorkbook property). Remarks фрилансер Excel, VBA — контакты в профиле |
Hugo Пользователь Сообщений: 23251 |
Set WBN = Workbooks.Add(xlWBATWorksheet) ‘создание новой книги с одним листом |
Hugo Пользователь Сообщений: 23251 |
Припоздал, но зато проверил (4 варианта): Sub tt() Set sh = Workbooks.Add(-4167).Worksheets(1): sh.Name = «Массив» |
В продолжение этой темы, здесь я выяснил, что создавать книгу с одним листом можно с помощью команды Set WBB = Workbooks.Add(1) а вот теперь у меня произошел косяк и я не знаю как создать книгу с тремя листами, потому что команда Set WBB = Workbooks.Add создает книгу с одним листом! |
|
А если в команде Set WBB = Workbooks.Add(1) поменять единицу на 2 или тройку, то меняется тип книги, диаграмма или мокрокнига |
|
The_Prist Пользователь Сообщений: 14182 Профессиональная разработка приложений для MS Office |
Application.SheetsInNewWorkbook = 3 Даже самый простой вопрос можно превратить в огромную проблему. Достаточно не уметь формулировать вопросы… |
Казанский Пользователь Сообщений: 8839 |
#10 25.06.2012 11:22:13 Создать книгу с произвольным числом листов можно так: Sub bb() |
- Володя
- Начинающий
- Сообщения: 6
- Зарегистрирован: 26.06.2003 (Чт) 14:45
- Откуда: Москва
Создание книги Excel с одним листом
Привет, специалисты!
Подскажите, как создать книгу Excel с одним (!) листом. Потому что если воспользоваться традиционной функцией Workbooks.Add создается книга с тем количеством листов, которое есть в настройке Экселя.
Заранее благодарен, Володя.
- Vitaly1
- Брехман
- Сообщения: 1578
- Зарегистрирован: 30.12.2002 (Пн) 16:35
- Откуда: Russia, Mosсow
Vitaly1 » 26.06.2003 (Чт) 16:07
Надо удалить лишнии листы созданной книги:
n = ActiveWorkbook.Worksheets.Count
For i = n To 2 Step -1
Application.DisplayAlerts = False
ActiveWorkbook.Worksheets(i).Delete
Application.DisplayAlerts = True
Next i
- Vitaly1
- Брехман
- Сообщения: 1578
- Зарегистрирован: 30.12.2002 (Пн) 16:35
- Откуда: Russia, Mosсow
Vitaly1 » 26.06.2003 (Чт) 16:18
Елки, палки, да там параметр есть сколько листов(это с одним):
Workbooks.Add 1
- Володя
- Начинающий
- Сообщения: 6
- Зарегистрирован: 26.06.2003 (Чт) 14:45
- Откуда: Москва
Володя » 26.06.2003 (Чт) 16:30
Спасибо, Виталий!!! Очень ценное предложение !!!
Заранее благодарен, Володя.
Вернуться в VBA
Кто сейчас на конференции
Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 2
�������� ����� � ����� ������
�������� ����� � ����� ������
� �������� ������ ������ ��������� ������������� �������� ������� �����, ��������� ������ �� ������ �����. �����, �������, ������� ������� ����� ����� � ������� ������� �������� ����� (�������, ��� ��� �������� ���������� �������� ������ ������� ���� �� ������ � ������ ����� � ������� � ����������� ���� ����� �������). ������ ��� ������� ������ ������ ��� �� �������������� ��������������� ������ VBA � �������� ������, ��� �������� �������� � �������� 2.3.
������� 2.3. ����� � ����� ������
Sub NewOneSheetBook()
Workbooks.Add xlWBATWorksheet
End Sub
� ���������� ���������� ������� ������� ����� ������� ����� ������� �����, � ������ ������� ������ ������ ���� ������� ����. ��� ����� ����� ������� � ��������� ����.
5 / 5 / 0 Регистрация: 08.05.2011 Сообщений: 215 |
|
1 |
|
03.04.2014, 14:02. Показов 11422. Ответов 12
Собственно сабж, пробовал один способ, но он работает немного неправильно. СОздает файл, но там почему то есть все листы с предыдущей рабочей книги. Подскажите пожалуйста.
0 |
Programming Эксперт 94731 / 64177 / 26122 Регистрация: 12.04.2006 Сообщений: 116,782 |
03.04.2014, 14:02 |
Ответы с готовыми решениями: Создать новый файл с именем S, содержащий ненулевую часть произведения A*B saveFileDialog как создать новый файл с указанным именем, если его не существует Создать новый файл с именем NameD, в котором чередовались бы элементы исходных файлов Даны три файла… Создать новый текстовый файл с именем Name3, являющийся объединением содержимого файлов Name1 и Name2 12 |
Заблокирован |
||||
03.04.2014, 14:16 |
2 |
|||
Создать новый *.xlsx файл с одним листом и именем Ouput
0 |
Казанский 15136 / 6410 / 1730 Регистрация: 24.09.2011 Сообщений: 9,999 |
||||
03.04.2014, 14:21 |
3 |
|||
Скорее так
0 |
Hugo121 6875 / 2807 / 533 Регистрация: 19.10.2012 Сообщений: 8,562 |
||||
03.04.2014, 14:21 |
4 |
|||
0 |
5 / 5 / 0 Регистрация: 08.05.2011 Сообщений: 215 |
|
03.04.2014, 14:22 [ТС] |
5 |
Не-не, в том то и дело. ЧТо я сначала создаю файл, а потом только лист в нем, ничего не копирую.
0 |
6875 / 2807 / 533 Регистрация: 19.10.2012 Сообщений: 8,562 |
|
03.04.2014, 14:24 |
6 |
Создать файл без листов невозможно.
1 |
5 / 5 / 0 Регистрация: 08.05.2011 Сообщений: 215 |
|
03.04.2014, 14:26 [ТС] |
7 |
Ок, тогда поставим по-другому вопрос. Данных для Output — листа не существует. Туда они только попадут, когда будет файл Output.xlsx с листом Output. Вот, что я имею ввиду.
0 |
15136 / 6410 / 1730 Регистрация: 24.09.2011 Сообщений: 9,999 |
|
03.04.2014, 14:26 |
8 |
Тогда возвращаемся к началу.
пробовал один способ, но он работает немного неправильно Какой способ, что неправильно?
0 |
zzz_ 5 / 5 / 0 Регистрация: 08.05.2011 Сообщений: 215 |
||||
03.04.2014, 14:37 [ТС] |
9 |
|||
Пока писали, пытался сам решить и решил. Вот, если кому надо.
0 |
6875 / 2807 / 533 Регистрация: 19.10.2012 Сообщений: 8,562 |
|
03.04.2014, 14:47 |
10 |
А что с другими листами? По коду не видно… Просили ведь один лист — я подсказал, а не использовали…
0 |
5 / 5 / 0 Регистрация: 08.05.2011 Сообщений: 215 |
|
03.04.2014, 15:00 [ТС] |
11 |
Вплане другими листами. Я проверил, создается только один лист. Нет, VBA не из под EXCEL.
0 |
Казанский 15136 / 6410 / 1730 Регистрация: 24.09.2011 Сообщений: 9,999 |
||||
03.04.2014, 15:01 |
12 |
|||
zzz_, вызывает ошибку, если файл уже существует.
0 |
5 / 5 / 0 Регистрация: 08.05.2011 Сообщений: 215 |
|
03.04.2014, 15:13 [ТС] |
13 |
Я там код исправлял, никаких ошибок не должно быть. Если файл не существует — даже объект не создадим.
0 |
Данная функция формирует (создаёт) новую книгу Excel с одним листом (на основании шаблона — листа sh_template), после чего сохраняет новый файл по пути NewFilename$
Если путь не указан, сохранения нового файла не происходит.
Function NewWorksheet(ByRef sh_template As Worksheet, Optional ByVal NewFilename$) As Worksheet Application.ScreenUpdating = False: On Error Resume Next: Err.Clear shtv = sh_template.Visible: sh_template.Visible = xlSheetVisible If Err Then MsgBox "Не удалось отобразить лист шаблона", vbCritical, "Ошибка в функции NewWorksheet ": End sh_template.Copy: DoEvents sh_template.Visible = shtv If Err Then MsgBox "Не удалось скопировать лист шаблона", vbCritical, "Ошибка в функции NewWorksheet ": End If ActiveWorkbook.Worksheets.Count > 1 Then MsgBox "2: Не удалось скопировать лист шаблона", vbCritical, "Ошибка в функции NewWorksheet ": End If ActiveWorkbook.Name = ThisWorkbook.Name Then MsgBox "3: Не удалось скопировать лист шаблона", vbCritical, "Ошибка в функции NewWorksheet ": End Set NewWorksheet = ActiveWorkbook.Worksheets(1) If NewWorksheet.Name <> sh_template.Name Then MsgBox "4: Не удалось скопировать лист шаблона", vbCritical, "Ошибка в функции NewWorksheet ": End Err.Clear: If Len(NewFilename$) Then ActiveWorkbook.SaveAs NewFilename$, xlWorkbookNormal If Err Then MsgBox "Не удалось сохранить новый файл по пути" & vbNewLine & _ """" & NewFilename$ & """", vbExclamation, "Ошибка в функции NewWorksheet " End Function
Пример использования:
Dim sh As Worksheet: Set sh = NewWorksheet(sht, НовыйПутьКФайлу$)
- 18713 просмотров
Не получается применить макрос? Не удаётся изменить код под свои нужды?
Оформите заказ у нас на сайте, не забыв прикрепить примеры файлов, и описать, что и как должно работать.
Работа с книгой Excel
создание, сохранение, закрытие, открытие
В этом уроке я продемонстрирую способы создания книги Excel, её сохранение, закрытие и всё это средствами VBA.
Создание новой книги Excel
Для того чтобы создать новую книгу, лист или что-то другое используют команду Add. Следовательно, для того чтобы создать новую книгу необходимо из выпадающего списка при написании команды книги выбрать Add:
Sub primer1()
Workbooks.Add
End Sub
Но при такой записи книга создаётся с настройками по умолчанию, т.е. если у Вас в Excel написано, что при создании новой книги в ней создавать 3 листа, то при написании вышеуказанной команды у Вас создастся книга с 3 листами. Почему я на это обратил внимание? Исходя из личного опыта знаю, что при формировании новых книг требуется создать книгу с указанным количеством листов. В примере ниже указано как создать книгу с одним листом.
Sub primer2()
Workbooks.Add (xlWBATWorksheet)
End Sub
Для того чтобы создать книгу с большим количеством листов необходимо дописать предыдущий код и указать дополнительное количество создаваемых листов. Смотрим.
Sub primer3()
Workbooks.Add(xlWBATWorksheet).Worksheets.Add , , 2
End Sub
или
Sub primer4()
Workbooks.Add(xlWBATWorksheet).Worksheets.Add Count:=2
End Sub
В этом примере создаётся книга с одним листом и дополнительно в ней создаётся ещё два листа, то-есть книга с 3 листами.
Сохранение книги
Если Вы хотите убить сразу двух зайцев, создать книгу и сразу же её сохранить в нужном месте, то можете воспользоваться комбинированной командой:
Sub primer5()
Workbooks.Add.SaveAs «c:12345»
End Sub
Обратите особое внимание на подсказку при вводе данных. На ней явно показано какие именно параметры Вы можете установить на книгу при её сохранении, например поставить пароль на книгу.
Ниже представлен пример сохранения книги с паролем — 123
Sub primer6()
Workbooks.Add.SaveAs «C:12345», , «123»
End Sub
или
Sub primer7()
Workbooks.Add.SaveAs Filename:=»C:12345″, Password:=»123″
End Sub
Из всего выше приведённого хочу сделать одно весомое замечание. При сохранении книги она будет использовать тот формат, который у Вас установлен по умолчанию. В данном случае я работаю на 2010 версии Excel и у меня по умолчанию стоит формат с расширением .xlsx. Если вы хотите сохранить файл с другим расширением, то вам в коде необходимо прописать следующие параметры.
Sub primer8()
Workbooks.Add.SaveAs Filename:=»C:12345″, FileFormat:=xlNormal
End Sub
При такой записи файл автоматически будет сохраняться с расширением .xls. Вы можете и сами указать расширение файла в адресе файла, что приветствуется. Например:
Sub primer9()
Workbooks.Add.SaveAs Filename:=»C:12345.xls», FileFormat:=xlNormal
End Sub
Если у Вас книга уже создана и Вы её просто хотите сохранить в нужном месте, то можно воспользоваться следующими записями.
Для сохранения текущей книги:
ThisWorkbook.SaveAs Filename:=»C:12345.xls», FileFormat:=xlNormal
Для сохранения активной книги:
ActiveWorkbook.SaveAs Filename:=»C:12345.xls», FileFormat:=xlNormal
Что будет если не указать путь сохранения книги? Она у Вас сохранится по умолчанию в коренной папке, в винде это обычно папка «Мои документы».
Если у Вас уже сохранена книга на компьютере и Вы время от времени её редактируете, но сохранять вы хотите её при помощи какого-то макроса на том же самом месте, то для такой процедуры можно воспользоваться банальной надписью (сохранить эту книгу):
ThisWorkbook.Save
Возможно многие загнались вопросом: А как сохранить книгу в текущей папке? То-есть там где открыт корееной файл — Ваша программа. Есть такая интересная штука, которая определяет коренной путь активного файла. А зная коренной путь файла, мы можем новый создаваемый файл сохранить в текущей папке с вашей программой, что очень удобно. Например:
Sub primer10()
ChDir ThisWorkbook.Path
Workbooks.Add.SaveAs Filename:=ThisWorkbook.Path & «12345.xls», _
FileFormat:=xlNormal
End Sub
Казалось бы всё основное рассмотрели, но оказывается есть ещё один интересный способ сохранения. Все его знают. Это когда мы сами указываем имя книги и путь её сохранения, т.е. нам показывается такое окно:
Делается это при помощи команды GetSaveAsFilename. Например, можно выполнить сохранение так:
Sub primer101()
fileSaveName = Application.GetSaveAsFilename(fileFilter:=»File (*.xls), *.xls»)
If fileSaveName False Then
ThisWorkbook.SaveAs Filename:=fileSaveName, FileFormat:=xlNormal
MsgBox «Сохранено как » & fileSaveName, vbInformation, «Сохранён»
End If
End Sub
При этом fileFilter устанавливает ограничение на то, в каких именно расширениях можно сохранять книги. Но не забывайте про FileFormat, если устанавливаете несколько форматов сохранения файла.
Закрытие книги
Для того чтобы закрыть книгу можно применить следующие команды:
Для закрытия текущей и активной книги:
ThisWorkbook.Close
ActiveWorkbook.Close
Если у Вас открыто несколько книг и Вам необходимо закрыть определённую книгу, то Вы можете указать имя закрываемой книги, например:
Sub primer13()
Workbooks(«12345.xls»).Close
End Sub
И всё бы хорошо, но при закрытии книги бывает выползает сообщение
Для того чтобы не появлялось такое сообщение необходимо перед закрытием книги её сохранить, например:
Sub primer13()
Workbooks(«12345.xls»).Save
Workbooks(«12345.xls»).Close
End Sub
Если вы не хотите сохранять книгу, но вам необходимо её закрыть (предположим вы взяли из неё какие-то данные), то можно воспользоваться следующей записью, которую рассматривали в этом уроке. Книга закроется без сохранения, даже если в неё были внесены изменения.
Sub primer14()
Application.DisplayAlerts = False
Workbooks(«12345.xls»).Close
Application.DisplayAlerts = True
End Sub
Открытие документов Excel
Для того чтобы открыть книгу Excel нужно всего-то указать путь открываемого файла. Программно это будет выглядеть так:
Sub primer15()
Workbooks.Open «D:РаботаVBAerror.xls»
End Sub
Если Вы не знаете где находится файл, то можно воспользоваться командой GetOpenFilename. При использовании этой команды нам появится окно, в котором, так же как и при сохранении книги, можно указать расширения открываемых файлов.
На этом примере показано, что разрешено открыть два типа файлов — с расширением xls и расширением xlsx.
Sub primer16()
fileToOpen = Application.GetOpenFilename _
(«Files (*.xls), *.xls,Files (*.xlsx), *.xlsx»)
If fileToOpen False Then
MsgBox «Открывается файл » & fileToOpen
Workbooks.Open fileToOpen
End If
End Sub
Открытие сторонних программ
средствами VBA
Все загонялись таким вопросом — Как открыть из Excel другую программу или файл, например PDF, DOC или обычный калькулятор? Сегодня я хочу устранить этот вопрос. Существует несколько способов открытия. Я не буду заморачиваться и лезть в дебри, а покажу тот которым пользуюсь я. Способ, который всегда работает и который понятен.
Мы говорили о том как можно открыть книгу Excel в предыдущем уроке, но как открыть сторонний документ? Практически любую программу или файл можно открыть при момощи команды Shell. Но тут необходимо соблюдать следующую последовательность открытия файла:
1. необходимо запустить программу при помощи которой будет происходить открытие документа. Например, для открытия документа с расширением .doc нам необходимо запустить Word.
2. открыть файл.
ВНИМАНИЕ! Все примеры, которые будут демонстрироваться ниже, исключительно на программах, которые установлены у меня. У вас этих программ может не оказаться или иметь совершенно другой путь.
Открываем документы Word
Для того чтобы открыть документ Word необходимо руководствоваться выше указанной последовательностью. На примере это будет выглядеть так
Sub WordOpen()
‘Открываем программу, которая открывает документ
Programm = «c:Program FilesMicrosoft OfficeOffice14winword.exe»
‘Указываем адрес файла
File = «c:1.docx»
‘Открываем Файл
Shell Programm & » » & File, vbNormalFocus
End Sub
Это же можно записать без присвоения к переменным, но это выглядит одной длинной строчкой, что иногда не очень удобно.
Sub WordOpen()
Shell «c:Program FilesMicrosoft OfficeOffice14winword.exe» _
& » » & «c:1.docx», vbNormalFocus
End Sub
Ну а если указанного файла или программы нет, то можно воспользоваться командами обработки ошибок.
Sub WordOpen()
On Error GoTo Errorr
Shell «c:Program FilesMicrosoft OfficeOffice14winword.exe» _
& » » & «c:2.docx», vbNormalFocus
GoTo Ends
Errorr:
MsgBox «Файл не найден», vbCritical, «Ошибка»
Ends:
End Sub
vbNormalFocus — этот параметр показывает как именно открыть окно. В данном случае это говорит о том, что Окно в фокусе и открывается до исходного размера и положения.
Существует несколько типов констант открытия окон:
Константа |
Значение |
Описание |
vbHide |
0 |
Указывает, что при вызове функции Shell окно вызванной программы становится скрытым. |
vbNormalFocus |
1 |
Указывает, что при вызове функции Shell окно вызванной программы принимает обычный размер и фокус находится внутри него. |
vbMinimizedFocus |
2 |
Указывает, что при вызове функции Shell окно вызванной программы сворачивается и фокус находится внутри него. |
vbMaximizedFocus |
3 |
Указывает, что при вызове функции Shell окно вызванной программы разворачивается во весь экран и фокус находится внутри него. |
vbNormalNoFocus |
4 |
Указывает, что при вызове функции Shell окно вызванной программы принимает обычный размер и фокус находится за его пределами. |
vbMinimizedNoFocus |
6 |
Указывает, что при вызове функции Shell окно вызванной программы сворачивается и фокус находится за его пределами. |
Открываем документы PDF
Оень распространён способ открытия документов PDF через Акробат, так как это одна из самых популярных программ. Но я ей не пользуюсь. Она слишком медленная и меня она не устраивает. Поэтому способ открытия при помощи программы Акробат я показывать не буду. А продемонстрирую как можно всё при пощи той же команды Shell открыть любой программой, которая Вам нравится для чтения PDF документов. Делается это по аналогии с предыдущими примерами. Только тут мы указываем программу для открытия PDF документов.
Sub PDFOpen()
‘Открываем программу, которая открывает документ
Programm = «c:Program FilesFoxit SoftwareFoxit ReaderFoxit Reader.exe»
‘Указываем адрес файла
Files = «c:jrc4558.pdf»
‘Открываем Файл
Shell Programm & » » & Files, vbNormalFocus
End Sub
Точно так же можно записать в одну строчку
Sub PDFOpen()
Shell «c:Program FilesFoxit SoftwareFoxit ReaderFoxit Reader.exe» & _
» » & «c:jrc4558.pdf», vbNormalFocus
End Sub
Открываем сторонние программы
По аналогии при помощи команды Shell можно открывать и отдельные программы. Например аудиопроигрыватель:
Sub AIMPOpen()
Shell «c:Program FilesAIMP3AIMP3.exe», vbNormalFocus
End Sub
или видеопроигрыватель
Sub VIDEOOpen()
Shell «c:Program FilesK-Lite Codec PackMedia Player Classicmpc-hc.exe», _
vbNormalFocus
End Sub
При этом путь к некоторым праграммам, можно не указывать.
Sub CalcOpen()
Call Shell(«Calc.exe», 1)
End Sub
или таким образом
Sub CalcOpen()
Shell «Calc.exe», 1
End Sub
Или можно вызвать справку Windows
Sub HelpOpen()
Call Shell(«winhelp.exe», 1)
End Sub
Открываем программу Word
Sub winwordOpen()
Shell «winword.exe», 1
End Sub
Открываем командную строку
Sub CmdOpen()
Shell «cmd.exe», 1
End Sub
Думаю, что стальные программы Вы теперь сами сможете открыть на основе этих примеров.
аблица символов
Все давно знают, что буквы и цифры — это обыкновенный код в определённой таблице символов.
ASCII (англ. American Standard Code for Information Interchange) — американская стандартная кодировочная таблица для печатных символов и некоторых специальных кодов.
ASCII представляет собой кодировку для представления десятичных цифр, латинского и национального алфавитов, знаков препинания и управляющих символов. Изначально разработанная как 7-битная, с широким распространением 8-битного байта ASCII стала восприниматься как половина 8-битной. В компьютерах обычно используют расширения ASCII с задействованным 8-м битом и второй половиной кодовой таблицы (например КОИ-8).
(Источник: Википедия)
Для чего вообще я затронул эту тему? Это больше для справки дано. Но и Excel не оставлю без внимания. Зная коды символов при помощи обычных циклов можно предположим перебрать все символы, которые у нас имеются. Ниже приведены две таблицы символов — от 0 до 127 и от 128 до 255. Символы с кодами от 0 до 31 относятся к служебным.
Символ 0 — 127
0 |
32 |
[space] |
64 |
@ |
96 |
` |
|
1 |
33 |
! |
65 |
A |
97 |
a |
|
2 |
34 |
« |
66 |
B |
98 |
b |
|
3 |
35 |
# |
67 |
C |
99 |
c |
|
4 |
36 |
$ |
68 |
D |
100 |
d |
|
5 |
37 |
% |
69 |
E |
101 |
e |
|
6 |
38 |
& |
70 |
F |
102 |
f |
|
7 |
39 |
‘ |
71 |
G |
103 |
g |
|
8 |
40 |
( |
72 |
H |
104 |
h |
|
9 |
41 |
) |
73 |
I |
105 |
i |
|
10 |
42 |
* |
74 |
J |
106 |
j |
|
11 |
43 |
+ |
75 |
K |
107 |
k |
|
12 |
44 |
, |
76 |
L |
108 |
l |
|
13 |
45 |
— |
77 |
M |
109 |
m |
|
14 |
46 |
. |
78 |
N |
110 |
n |
|
15 |
47 |
/ |
79 |
O |
111 |
o |
|
16 |
48 |
0 |
80 |
P |
112 |
p |
|
17 |
49 |
1 |
81 |
Q |
113 |
q |
|
18 |
50 |
2 |
82 |
R |
114 |
r |
|
19 |
51 |
3 |
83 |
S |
115 |
s |
|
20 |
52 |
4 |
84 |
T |
116 |
t |
|
21 |
53 |
5 |
85 |
U |
117 |
u |
|
22 |
54 |
6 |
86 |
V |
118 |
v |
|
23 |
55 |
7 |
87 |
W |
119 |
w |
|
24 |
56 |
8 |
88 |
X |
120 |
x |
|
25 |
57 |
9 |
89 |
Y |
121 |
y |
|
26 |
58 |
: |
90 |
Z |
122 |
z |
|
27 |
59 |
; |
91 |
[ |
123 |
{ |
|
28 |
60 |
92 |
124 |
| |
|||
29 |
61 |
= |
93 |
] |
125 |
} |
|
30 |
62 |
94 |
^ |
126 |
~ |
||
31 |
63 |
? |
95 |
_ |
127 |
8, 9, 10 и 13 не имеют графического представления, но, в зависимости от применения, могут влиять на визуальное отображение текста.
Символ 128 — 255
128 |
Ђ |
160 |
192 |
А |
224 |
а |
|
129 |
Ѓ |
161 |
Ў |
193 |
Б |
225 |
б |
130 |
‚ |
162 |
ў |
194 |
В |
226 |
в |
131 |
ѓ |
163 |
Ј |
195 |
Г |
227 |
г |
132 |
„ |
164 |
¤ |
196 |
Д |
228 |
д |
133 |
… |
165 |
Ґ |
197 |
Е |
229 |
е |
134 |
† |
166 |
¦ |
198 |
Ж |
230 |
ж |
135 |
‡ |
167 |
§ |
199 |
З |
231 |
з |
136 |
€ |
168 |
Ё |
200 |
И |
232 |
и |
137 |
‰ |
169 |
© |
201 |
Й |
233 |
й |
138 |
Љ |
170 |
Є |
202 |
К |
234 |
к |
139 |
‹ |
171 |
« |
203 |
Л |
235 |
л |
140 |
Њ |
172 |
¬ |
204 |
М |
236 |
м |
141 |
Ќ |
173 |
— |
205 |
Н |
237 |
н |
142 |
Ћ |
174 |
® |
206 |
О |
238 |
о |
143 |
Џ |
175 |
Ї |
207 |
П |
239 |
п |
144 |
ђ |
176 |
° |
208 |
Р |
240 |
р |
145 |
‘ |
177 |
± |
209 |
С |
241 |
с |
146 |
’ |
178 |
І |
210 |
Т |
242 |
т |
147 |
“ |
179 |
і |
211 |
У |
243 |
у |
148 |
” |
180 |
ґ |
212 |
Ф |
244 |
ф |
149 |
• |
181 |
µ |
213 |
Х |
245 |
х |
150 |
– |
182 |
¶ |
214 |
Ц |
246 |
ц |
151 |
— |
183 |
· |
215 |
Ч |
247 |
ч |
152 |
184 |
ё |
216 |
Ш |
248 |
ш |
|
153 |
™ |
185 |
№ |
217 |
Щ |
249 |
щ |
154 |
љ |
186 |
є |
218 |
Ъ |
250 |
ъ |
155 |
› |
187 |
» |
219 |
Ы |
251 |
ы |
156 |
њ |
188 |
ј |
220 |
Ь |
252 |
ь |
157 |
ќ |
189 |
Ѕ |
221 |
Э |
253 |
э |
158 |
ћ |
190 |
ѕ |
222 |
Ю |
254 |
ю |
159 |
џ |
191 |
ї |
223 |
Я |
255 |
я |
Применение
Теперь можно приступить непосредственно к примерам. Как я получил все эти символы? Конечно же я не сидел и не набирал их из таблицы символов в Excel. Всё это делается гораздо проще. Существует очень интересная команда, которая способна из номера символа показать нам его символ.
Chr(charcode) — возвращает строку, содержащую символ, связанный с указанным кодом символа. Другими словами мы задаём номер символа, а нам выдаётся символ.
А если воспользоваться циклом и записать это в виде макроса, то можно получить сразу всю таблицу символов за считанные секунды.
Sub tablica()
For a = 0 To 255
Cells(a + 1, 2) = a
Cells(a + 1, 1) = Chr(a)
Next a
Beep ‘Гудок
End Sub
Chr(a) — в этой записи переменная a принимает значения от 0 до 255. Всё согласно написанному циклу.
Beep — это сигнал компьютера. В данном случае сигнализирует о прекращении выполнении макроса.
Хочу ещё кое-что отметить. В одном из уроков мы рассматривали как можно перенести текст в Msgbox на новую строку. Делается это при помощи команды vbNewLine. Так вот эту же команду можно выполнить при помощи записи Chr(13), которая так же означает перенос на новую строку.
Sub Primer()
MsgBox «Это первая строка» & vbNewLine & _
«Это вторая строка», vbInformation, «Пример»
End Sub
или
Sub Primer()
MsgBox «Это первая строка» & Chr(13) & _
«Это вторая строка», vbInformation, «Пример»
End Sub
Так же можно отобразить символ в информационном сообщении.
Sub Primer2()
MsgBox «Символ Chr(89) — это » & Chr(89), vbInformation, «Пример»
End Sub
Теперь зная как получить символы можно писать программы для подбора паролей. :-))
Запуск макроса из другого макроса
Отдельно написаный макрос — это хорошо, но ещё лучше если макросы будут запускать сами себя. Предположим один макрос выполняет анализ документа, второй редактирует документ, третий делает отчётный документ. Ни каких лишних движений мышкой и вмешательства пользователей. Всё автоматизировано.
А теперь посмотрим как запустить макрос из другого макроса. Существует несколько способов. Предположим у нас есть 2 макроса, один из которых закрашивает ячейку в зелёный цвет, а другой закрашивает её в синий цвет.
Sub videlenie()
If Cells(1, 1).Interior.ColorIndex = 4 Then
Else
Cells(1, 1).Interior.ColorIndex = 4
MsgBox «Выполнена зелёная заливка», vbInformation, «Пример»
End If
End Sub
Sub okras()
ActiveCell.Interior.ColorIndex = 5
MsgBox «Выполнена синяя заливка», vbInformation, «Пример»
End Sub
Способ №1
Просто пишите имя макроса в том месте где вы хотите его выполнить. В данном случае он написан в условии Если … То.
Sub videlenie()
If Cells(1, 1).Interior.ColorIndex = 4 Then
okras
Else
Cells(1, 1).Interior.ColorIndex = 4
MsgBox «Выполнена зелёная заливка», vbInformation, «Пример»
End If
End Sub
Sub okras()
ActiveCell.Interior.ColorIndex = 5
MsgBox «Выполнена синяя заливка», vbInformation, «Пример»
End Sub
Если ячейка А1 имеет зелёный цвет, то запускается второй макрос (okras), который закрашивает её в синий цвет. Пройдите эти макросы через кнопку F8, дабы понять логику выполнения макроса. Это важно понимать.
Способ №2
Практически так же как и в предыдущем примере, только перед именем макроса добавляете командуCall.
Sub videlenie()
If Cells(1, 1).Interior.ColorIndex = 4 Then
Call okras
Else
Cells(1, 1).Interior.ColorIndex = 4
MsgBox «Выполнена зелёная заливка», vbInformation, «Пример»
End If
End Sub
Sub okras()
ActiveCell.Interior.ColorIndex = 5
MsgBox «Выполнена синяя заливка», vbInformation, «Пример»
End Sub
Не обязательно использовать оператор Call при вызове процедуры. Однако он повышает читаемость кода. Лично я всегда использую этот вариант.
Способ №3
Третий способ более замороченый (его дольше писать), но им тоже можно пользоваться. Макрос запускается при помощи команды Application.Run.
Sub videlenie()
If Cells(1, 1).Interior.ColorIndex = 4 Then
n = 1
Application.Run «okras»
Else
Cells(1, 1).Interior.ColorIndex = 4
MsgBox «Выполнена зелёная заливка», vbInformation, «Пример»
End If
End Sub
Sub okras()
ActiveCell.Interior.ColorIndex = 5
MsgBox «Выполнена синяя заливка» & n, vbInformation, «Пример»
End Sub
Ну вот. Теперь мы знаем как запускать макросы. Есть ещё один момент, который надо отметить. При запуске макросов иногда возникает необходимость переносить значения переменных из одного макроса в другой, чтобы в дальнейшем обработать необходимую информацию.
Перенос значений переменных из одного макроса в другой
Рассмотрим перенос значений переменных на двух простейших макросах.
Sub perenos()
a = 1
b = 2
c = a + b
End Sub
Sub rezultat()
MsgBox «Результат сложения» & vbNewLine & _
«a=1» & a & vbNewLine & _
«b=2» & b & vbNewLine & _
«равен » & c, vbInformation, «Пример»
End Sub
Для того чтобы перенести значение переменной c в макрос с именем rezultat, необходимо в скобках с именем макроса указать ту переменную, значение которой вы хотите перенести. Выглядит это следующим образом.
Sub perenos()
a = 1
b = 2
c = a + b
Call rezultat(c)
End Sub
Sub rezultat(c)
MsgBox «Результат сложения» & vbNewLine & _
«a=1» & a & vbNewLine & _
«b=2» & b & vbNewLine & _
«равен » & c, vbInformation, «Пример»
End Sub
Обратите особое внимание, что при запуске макроса, в скобках так же надо указывать переменную Call rezultat(c), так как имя макроса изменилось. Теперь при запуске первого макроса у нас запускается второй макрос в котором нам отображается результат.
Теперь усложним и перенесём значение переменных a и b в макрос rezultat, и уже в нём произведём вычисление. Выглядеть это будет так:
Sub perenos1()
a = 1
b = 2
Call rezultat1(a, b)
End Sub
Sub rezultat1(a, b)
c = a + b
MsgBox «Результат сложения» & vbNewLine & _
«a=» & a & vbNewLine & _
«b=» & b & vbNewLine & _
«равен » & c, vbInformation, «Пример»
End Sub
Home / VBA / VBA Create New Workbook (Excel File)
To create a new workbook using VBA, you need to use the “Workbooks.Add” method. When you use this method, it inserts a new workbook (without saving it) and activates it after that. It works like when you press the keyboard shortcut CONTROL + N. You can also use a template to insert a new workbook.
Make sure to add the developer tab to the ribbon to enter this code into the VBE.
- Type the keyword “Workbooks” to refer to the workbook object.
- After that, type a dot.
- Here you’ll have a list of properties and methods to select.
- Select “Add” from that list or type it.
Sub vba_new_workbook()
Workbooks.Add
End Sub
Add a New Workbook using a Template
As I said, we are using the Workbooks.Add method. With this method, there’s an argument (optional) that you can use to refer to a file as a template.
Workbook.Add Template (Optional)
Let’s say you have a workbook and want to have the new workbook exactly the same as it, you can refer to it as a template.
Workbooks.Add Template:="C:UsersDellDesktopbook1.xlsx"
When you run the above code, it takes the reference from the “book1” which is saved on the desktop. The template workbook has 6 worksheets and the new workbook has exactly the same number of worksheets.
Apart from this, you can use the default arguments to decide what type of sheet you want to have in the new workbook.
- xlWBATChart: Chart Sheet
- xlWBATExcel4IntlMacroSheet: Macro Sheet Version 4
- xlWBATExcel4MacroSheet: Macro Sheet (International) Version 4
- xlWBATWorksheet: Worksheet
Create a New Excel Workbook and Save it
When you create a new workbook, Excel opens it but will not save it with the Add method. So for this, you need to use the SaveAs method.
Sub vba_create_workbook()
Workbooks.Add
ActiveWorkbook.SaveAs "C:usersdelldesktopmyBook.xlsx"
End Sub
- First, use the workbook.add to create a new workbook.
- Next, refer to the active workbook and use the SaveAs method.
- In the SaveAs method, use the path where you want to save the workbook along with the name of the file.
- In the end, run the code.
More on VBA Workbooks
VBA Save Workbook | VBA Close Workbook | VBA Delete Workbook | VBA ThisWorkbook | VBA Rename Workbook | VBA Activate Workbook | VBA Combine Workbook | VBA Protect Workbook (Unprotect) | VBA Check IF a Workbook is Open | VBA Open Workbook | VBA Check IF an Excel Workbook Exists in a Folder
- VBA Workbook