При организации данных в книгах нередко копируют рабочие листы из одной книги в другую. Действительно, Edit | Команду «Переместить» или «Копировать лист» я использую довольно часто, и я готов поспорить, что другие используют ее так же часто.

Как же тогда копировать листы в макрос? Ответ — использовать метод копирования с отдельным листом или группой листов.

Например, следующий код макроса скопирует текущий выбранный рабочий лист в новую книгу:

ActiveSheet.Copy

Это оно; одна строка — это все, что нужно для копирования рабочего листа в новую, безымянную книгу. После выполнения строки выбирается новая книга, и вы можете сохранить ее, используя код, подобный приведенному ниже. Первая строка кода сохраняет книгу, а вторая закрывает ее.

ActiveWorkbook.SaveAs Filename:="MyNewFile.xlsm", _   FileFormat:=xlOpenXMLWorkbookMacroEnabled ActiveWindow.Close

Если вы хотите скопировать определенный лист в другую книгу, вы делаете это, указав имя листа, который вы хотите скопировать, вместо использования объекта ActiveSheet:

Sheets("Sheet1").Copy

В этом примере лист с именем Sheet1 копируется из коллекции Sheets в новую книгу. Затем вы можете сохранить новую книгу, как уже обсуждалось.

Метод копирования при использовании с листами не ограничивается копированием по одному листу за раз. Если у вас выбрана группа листов, вы все равно можете использовать одну командную строку, чтобы скопировать их все в новую книгу.

Вот что сделано в этом макросе:

Sub CopyWorkbook()

Dim sCopyName As String

sCopyName = "My New Workbook.xlsm"



SelectedSheets.Copy     ActiveWorkbook.SaveAs Filename:=sCopyName, _       FileFormat:=xlOpenXMLWorkbookMacroEnabled End Sub

Обратите внимание на использование команды Копировать. Макрос будет работать независимо от того, выбран ли у вас один рабочий лист или пятьдесят; это не имеет значения. Если вместо этого вы хотите скопировать все рабочие листы из одной книги в другую, все, что вам нужно сделать, это внести одно изменение в макрос в строке, где вызывается метод копирования:

Sheets.Copy

Это скопирует всю коллекцию Sheets, которая состоит из всех листов в книге.

Следует отметить, что метод копирования предназначен не только для копирования листов в новую книгу; его также можно использовать для копирования листов в той же книге. Единственное, что вам нужно сделать, это указать, где в текущей книге вы хотите сделать копию:

ActiveSheet.Copy After:=Sheets("Sheet7")

Эта строка кода копирует активный рабочий лист в ту же книгу, чтобы он отображался после рабочего листа с именем Sheet7. Если это более соответствует вашим потребностям, вы можете вместо этого указать рабочий лист, перед которым должна быть размещена копия:

ActiveSheet.Copy Before:=Sheets("Sheet7")

Это приводит к тому, что рабочий лист помещается перед Sheet7, а не после него.

_Примечание: _

Если вы хотите узнать, как использовать макросы, описанные на этой странице (или на любой другой странице на сайтах ExcelTips), я подготовил специальную страницу, содержащую полезную информацию.

link: / excelribbon-ExcelTipsMacros [Щелкните здесь, чтобы открыть эту специальную страницу в новой вкладке браузера].

ExcelTips — ваш источник экономичного обучения Microsoft Excel.

Этот совет (2784) применим к Microsoft Excel 97, 2000, 2002 и 2003. Вы можете найти версию этого совета для ленточного интерфейса Excel (Excel 2007 и более поздних версий) здесь:

link: / excelribbon-Copying_Worksheets_in_a_Macro [Копирование рабочих листов в макросе].