Vba excel ссылка на текущий лист

Обращение к рабочим листам Excel из кода VBA. Переименование листов, скрытие и отображение с помощью кода VBA Excel. Свойства Worksheets.Name и Worksheets.Visible.

Обращение к рабочим листам

Рабочий лист (Worksheet) принадлежит коллекции всех рабочих листов (Worksheets) книги Excel. Обратиться к листу можно как к элементу коллекции и, напрямую, по его уникальному имени.

Откройте редактор VBA и обратите внимание на вашу книгу в проводнике, где уникальные имена листов указаны без скобок, а в скобках — имена листов, отображаемые на ярлычках в открытой книге Excel. Уникальные имена листов отсортированы по алфавиту и их расположение по порядку не будет соответствовать их индексам (номерам), если листы перемещались по отношению друг к другу. Индексы листов смотрите по порядку расположения ярлычков в открытой книге. Переместили листы — изменились их индексы.

Обращение к рабочему листу в коде VBA Excel:

‘По уникальному имени

УникИмяЛиста

‘По индексу

Worksheets(N)

‘По имени листа на ярлычке

Worksheets(«Имя листа»)

  • УникИмяЛиста — уникальное имя листа, отображаемое в проводнике редактора VBA без скобок, с помощью кода VBA изменить его невозможно.
  • N — индекс листа от 1 до количества всех листов в книге, соответствует порядковому номеру ярлычка этого листа в открытой книге Excel.
  • Имя листа — имя листа, отображаемое в проводнике редактора VBA в скобках, с помощью кода VBA изменить его можно.

Количество листов в рабочей книге Excel определяется так:

‘В активной книге

Worksheets.Count

‘В любой открытой книге,

‘например, в «Книга1.xlsm»

Workbooks(«Книга1.xlsm»).Worksheets.Count

Переименование листов

В VBA Excel есть некоторые особенности в наименовании листов, так как у рабочего листа есть два свойства, связанных с именем: (Name) и Name. Откройте окно «Properties» в редакторе VBA, нажав клавишу «F4», и выделите любой лист в проводнике. Вы увидите, что в окне «Properties» свойству (Name) в скобках соответствует в проводнике уникальное имя листа без скобок, а свойству Name без скобок соответствует изменяемое имя листа в скобках. Оба имени в окне «Properties» можно редактировать.

С помощью кода VBA Excel можно редактировать только имя листа Name, отображаемое на ярлычке листа и в проводнике без скобок. Для этого используется свойство рабочего листа Worksheets.Name со следующим синтаксисом:

expression.Name

где expression — переменная, представляющая собой объект Worksheet. Смена имени осуществляется путем присвоения нового значения свойству Worksheets.Name.

Допустим, у нас есть лист с уникальным именем (Name) — Лист1, индексом — 1 и именем Name — МойЛист, которое необходимо заменить на имя — Реестр.

Лист1.Name = «Реестр»

Worksheets(1).Name = «Реестр»

Worksheets(«МойЛист»).Name = «Реестр»

Скрытие и отображение листов

Для скрытия и отображения рабочих листов в VBA Excel используется свойство Worksheet.Visible со следующим синтаксисом:

expression.Visible

где expression — переменная, представляющая собой объект Worksheet. Свойству Worksheet.Visible могут присваиваться следующие значения:

  • False — лист становится невидимым, но он будет присутствовать в списке скрытых листов, и пользователь сможет его отобразить с помощью инструментов рабочей книги Excel.
  • xlVeryHidden — лист становится супер невидимым и его не будет в списке скрытых листов, пользователь не сможет его отобразить. Актуально для Excel 2003-2016.
  • True — лист становится видимым.

Аналоги присваиваемых значений:

  • False = xlHidden = xlSheetHidden = 1
  • xlVeryHidden = xlSheetVeryHidden = 2
  • True = xlSheetVisible = -1 (константа xlVisible вызывает ошибку)

Примеры:

Лист1.Visible = xlSheetHidden

Лист2.Visible = 1

Worksheets(Worksheets.Count).Visible = xlVeryHidden

Worksheets(«МойЛист»).Visible = True

Как создать, скопировать, переместить или удалить рабочий лист с помощью кода VBA Excel, смотрите в этой статье.

I would like to create an user-defined function in Excel that can return the current worksheet. I could use the

sheetname = ActiveSheet.Name

But the problem with this is, it works and suddenly it starts to get different sheet name. For example, instead of SHEET I LOVE YOU it returns SHEET I HATE YOU.

Is there anyway to fix this — or it might possible because I think it can not be static but varies?

Community's user avatar

asked Oct 11, 2013 at 16:47

user2103670's user avatar

user2103670user2103670

1,59110 gold badges22 silver badges24 bronze badges

0

Function MySheet()

  ' uncomment the below line to make it Volatile
  'Application.Volatile
   MySheet = Application.Caller.Worksheet.Name

End Function

This should be the function you are looking for

sapbucket's user avatar

sapbucket

6,64514 gold badges55 silver badges94 bronze badges

answered Oct 11, 2013 at 17:03

mucio's user avatar

0

This works for me.

worksheetName = ActiveSheet.Name  

answered Oct 17, 2017 at 19:20

moberme's user avatar

mobermemoberme

6597 silver badges13 bronze badges

2

Sub FnGetSheetsName()

    Dim mainworkBook As Workbook

    Set mainworkBook = ActiveWorkbook

    For i = 1 To mainworkBook.Sheets.Count

    'Either we can put all names in an array , here we are printing all the names in Sheet 2

    mainworkBook.Sheets("Sheet2").Range("A" & i) = mainworkBook.Sheets(i).Name

    Next i

End Sub

TylerH's user avatar

TylerH

20.6k64 gold badges76 silver badges97 bronze badges

answered Nov 14, 2015 at 8:22

josef's user avatar

josefjosef

8449 silver badges8 bronze badges

Extend Code for Show Selected Sheet(s) [ one or more sheets].

Sub Show_SelectSheet()
  For Each xSheet In ThisWorkbook.Worksheets
     For Each xSelectSheet In ActiveWindow.SelectedSheets
         If xSheet.Name = xSelectSheet.Name Then
            '=== Show Selected Sheet ===
            GoTo xNext_SelectSheet
         End If
     Next xSelectSheet
  xSheet.Visible = False  
xNext_SelectSheet:
Next xSheet
MsgBox "Show Selected Sheet(s) Completed !!!"
end sub

answered Jun 12, 2019 at 8:36

ChaCha CJ Rune's user avatar

You can use below code to get the Active Sheet name and change it to yours preferred name.

Sub ChangeSheetName()

Dim shName As String
Dim currentName As String
currentName = ActiveSheet.Name
shName = InputBox("What name you want to give for your sheet")
ThisWorkbook.Sheets(currentName).Name = shName

End Sub

answered Oct 24, 2015 at 10:04

Rohit Pal's user avatar

i need to change the sheet name by the name of the file was opened

Sub Get_Data_From_File5()
    Dim FileToOpen As Variant
    Dim OpenBook As Workbook
    Dim currentName As String
    currentName = ActiveSheet.Name
    Application.ScreenUpdating = False
    FileToOpen = Application.GetOpenFilename(Title:="Browse for your File & Import Range", FileFilter:="Excel Files (*.csv*),*csv*")
    If FileToOpen <> False Then
        Set OpenBook = Application.Workbooks.Open(FileToOpen)
        OpenBook.Sheets(1).Range("A1:g5000").Copy
        ThisWorkbook.Worksheets(currentName).Range("Aw1:bc5000").PasteSpecial xlPasteValues
        OpenBook.Close False
       
        
    End If
    Application.ScreenUpdating = True
End Sub

Ian Campbell's user avatar

Ian Campbell

23k14 gold badges35 silver badges57 bronze badges

answered Dec 27, 2020 at 20:37

user14898005's user avatar

На чтение 16 мин. Просмотров 14.7k.

VBA Worksheet

Malcolm Gladwell

Мечтатель начинает с чистого листа бумаги и переосмысливает мир

Эта статья содержит полное руководство по использованию Excel
VBA Worksheet в Excel VBA. Если вы хотите узнать, как что-то сделать быстро, ознакомьтесь с кратким руководством к рабочему листу VBA ниже.

Если вы новичок в VBA, то эта статья — отличное место для начала. Мне нравится разбивать вещи на простые термины и объяснять их на простом языке.

Вы можете прочитать статью от начала до конца, так как она написана в логическом порядке. Или, если предпочитаете, вы можете использовать оглавление ниже и перейти непосредственно к теме по вашему выбору.

Содержание

  1. Краткое руководство к рабочему листу VBA
  2. Вступление
  3. Доступ к рабочему листу
  4. Использование индекса для доступа к рабочему листу
  5. Использование кодового имени рабочего листа
  6.  Активный лист
  7. Объявление объекта листа
  8. Доступ к рабочему листу в двух словах
  9. Добавить рабочий лист
  10. Удалить рабочий лист
  11. Цикл по рабочим листам
  12. Использование коллекции листов
  13. Заключение

Краткое руководство к рабочему листу VBA

В следующей таблице приведен краткий обзор различных методов
Worksheet .

Примечание. Я использую Worksheet в таблице ниже, не указывая рабочую книгу, т.е. Worksheets, а не ThisWorkbook.Worksheets, wk.Worksheets и т.д. Это сделано для того, чтобы примеры были понятными и удобными для чтения. Вы должны всегда указывать рабочую книгу при использовании Worksheets . В противном случае активная рабочая книга будет использоваться по умолчанию.

Задача Исполнение
Доступ к рабочему листу по
имени
Worksheets(«Лист1»)
Доступ к рабочему листу по
позиции слева
Worksheets(2)
Worksheets(4)
Получите доступ к самому
левому рабочему листу
Worksheets(1)
Получите доступ к самому
правому листу
Worksheets(Worksheets.Count)
Доступ с использованием
кодового имени листа (только
текущая книга)
Смотри раздел статьи
Использование кодового имени
Доступ по кодовому имени
рабочего листа (другая рабочая
книга)
Смотри раздел статьи
Использование кодового имени
Доступ к активному листу ActiveSheet
Объявить переменную листа Dim sh As Worksheet
Назначить переменную листа Set sh = Worksheets(«Лист1»)
Добавить лист Worksheets.Add
Добавить рабочий лист и
назначить переменную
Worksheets.Add Before:=
Worksheets(1)
Добавить лист в первую
позицию (слева)
Set sh =Worksheets.Add
Добавить лист в последнюю
позицию (справа)
Worksheets.Add after:=Worksheets(Worksheets.Count)
Добавить несколько листов Worksheets.Add Count:=3
Активировать рабочий лист sh.Activate
Копировать лист sh.Copy
Копировать после листа sh1.Copy After:=Sh2
Скопировать перед листом sh1.Copy Before:=Sh2
Удалить рабочий лист sh.Delete
Удалить рабочий лист без
предупреждения
Application.DisplayAlerts = False
sh.Delete
Application.DisplayAlerts = True
Изменить имя листа sh.Name = «Data»
Показать/скрыть лист sh.Visible = xlSheetHidden
sh.Visible = xlSheetVisible sh.Name = «Data»
Перебрать все листы (For) Dim i As Long
For i = 1 To Worksheets.Count
  Debug.Print Worksheets(i).Name
Next i
Перебрать все листы (For Each) Dim sh As Worksheet
For Each sh In Worksheets
    Debug.Print sh.Name
Next

Вступление

Три наиболее важных элемента VBA — это Рабочая книга, Рабочий лист и Ячейки. Из всего кода, который вы пишете, 90% будут включать один или все из них.

Наиболее распространенное использование Worksheet в VBA для доступа к его ячейкам. Вы можете использовать его для защиты, скрытия, добавления, перемещения или копирования листа.

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

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

Доступ к рабочему листу

В VBA каждая рабочая книга имеет коллекцию рабочих листов. В этой коллекции есть запись для каждого рабочего листа. Эта коллекция называется просто Worksheets и используется очень похоже на коллекцию Workbooks. Чтобы получить доступ к рабочему листу, достаточно указать имя.

Приведенный ниже код записывает «Привет Мир» в ячейках A1 на листах: Лист1, Лист2 и Лист3 текущей рабочей книги.

Sub ZapisVYacheiku1()

    ' Запись в ячейку А1 в листе 1, листе 2 и листе 3
    ThisWorkbook.Worksheets("Лист1").Range("A1") = "Привет Мир"
    ThisWorkbook.Worksheets("Лист2").Range("A1") = "Привет Мир"
    ThisWorkbook.Worksheets("Лист3").Range("A1") = "Привет Мир"

End Sub

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

Sub ZapisVYacheiku1()

    ' Worksheets относятся к рабочим листам в активной рабочей книге.
    Worksheets("Лист1").Range("A1") = "Привет Мир"
    Worksheets("Лист2").Range("A1") = "Привет Мир"
    Worksheets("Лист3").Range("A1") = "Привет Мир"

End Sub

Скрыть рабочий лист

В следующих примерах показано, как скрыть и показать лист.

ThisWorkbook.Worksheets("Лист1").Visible = xlSheetHidden

ThisWorkbook.Worksheets("Лист1").Visible = xlSheetVisible

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

' Скрыть от доступа пользователя
ThisWorkbook.Worksheets("Лист1").Visible = xlVeryHidden

' Это единственный способ сделать лист xlVeryHidden видимым
ThisWorkbook.Worksheets("Лист1").Visible = xlSheetVisible

Защитить рабочий лист

Другой пример использования Worksheet — когда вы хотите защитить его.

ThisWorkbook.Worksheets("Лист1").Protect Password:="Мойпароль"

ThisWorkbook.Worksheets("Лист1").Unprotect Password:="Мойпароль"

Индекс вне диапазона

При использовании Worksheets вы можете получить сообщение об
ошибке:

Run-time Error 9 Subscript out of Range

VBA Subscript out of Range

Это означает, что вы пытались получить доступ к рабочему листу, который не существует. Это может произойти по следующим причинам:

  1. Имя Worksheet , присвоенное рабочим листам, написано неправильно.
  2. Название листа изменилось.
  3. Рабочий лист был удален.
  4. Индекс был большим, например Вы использовали рабочие листы (5), но есть только четыре рабочих листа
  5. Используется неправильная рабочая книга, например Workbooks(«book1.xlsx»).Worksheets(«Лист1») вместо
    Workbooks(«book3.xlsx»).Worksheets («Лист1»).

Если у вас остались проблемы, используйте один из циклов из раздела «Циклы по рабочим листам», чтобы напечатать имена всех рабочих листов коллекции.

Использование индекса для доступа к рабочему листу

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

 В следующем коде показаны примеры использования индекса.

' Использование этого кода является плохой идеей, так как
' позиции листа все время меняются
Sub IspIndList()

    With ThisWorkbook
        ' Самый левый лист
        Debug.Print .Worksheets(1).Name
        ' Третий лист слева
        Debug.Print .Worksheets(3).Name
        ' Самый правый лист
        Debug.Print .Worksheets(.Worksheets.Count).Name
    End With

End Sub

В приведенном выше примере я использовал Debug.Print для печати в Immediate Window. Для просмотра этого окна выберите «Вид» -> «Immediate Window » (Ctrl + G).

ImmediateWindow

ImmediateSampeText

Использование кодового имени рабочего листа

Лучший способ получить доступ к рабочему листу —
использовать кодовое имя. Каждый лист имеет имя листа и кодовое имя. Имя листа
— это имя, которое отображается на вкладке листа в Excel.

Изменение имени листа не приводит к изменению кодового имени, что означает, что ссылка на лист по кодовому имени — отличная идея.

Если вы посмотрите в окне свойств VBE, вы увидите оба имени.
На рисунке вы можете видеть, что кодовое имя — это имя вне скобок, а имя листа
— в скобках.

code name worksheet

Вы можете изменить как имя листа, так и кодовое имя в окне
свойств листа (см. Изображение ниже).

Width

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

Sub IspKodImya2()

    ' Используя кодовое имя листа
    Debug.Print CodeName.Name
    CodeName.Range("A1") = 45
    CodeName.Visible = True

End Sub

Это делает код легким для чтения и безопасным от изменения
пользователем имени листа.

Кодовое имя в других книгах

Есть один недостаток использования кодового имени. Он относится только к рабочим листам в рабочей книге, которая содержит код, т.е. ThisWorkbook.

Однако мы можем использовать простую функцию, чтобы найти
кодовое имя листа в другой книге.

Sub ИспЛист()

    Dim sh As Worksheet
    ' Получить рабочий лист под кодовым именем
    Set sh = SheetFromCodeName("CodeName", ThisWorkbook)
    ' Используйте рабочий лист
    Debug.Print sh.Name

End Sub

' Эта функция получает объект листа из кодового имени
Public Function SheetFromCodeName(Name As String, bk As Workbook) As Worksheet

    Dim sh As Worksheet
    For Each sh In bk.Worksheets
        If sh.CodeName = Name Then
           Set SheetFromCodeName = sh
           Exit For
        End If
    Next sh

End Function

Использование приведенного выше кода означает, что если
пользователь изменит имя рабочего листа, то на ваш код это не повлияет.

Существует другой способ получения имени листа внешней
рабочей книги с использованием кодового имени. Вы можете использовать элемент
VBProject этой Рабочей книги.

Вы можете увидеть, как это сделать, в примере ниже. Я включил это, как дополнительную информацию, я бы рекомендовал использовать метод из предыдущего примера, а не этот.

Public Function SheetFromCodeName2(codeName As String _
                             , bk As Workbook) As Worksheet

    ' Получить имя листа из CodeName, используя VBProject
    Dim sheetName As String
    sheetName = bk.VBProject.VBComponents(codeName).Properties("Name")

    ' Используйте имя листа, чтобы получить объект листа
    Set SheetFromCodeName2 = bk.Worksheets(sheetName)

End Function

Резюме кодового имени

Ниже приведено краткое описание использования кодового имени:

  1. Кодовое имя рабочего листа может быть
    использовано непосредственно в коде, например. Sheet1.Range
  2. Кодовое имя будет по-прежнему работать, если имя
    рабочего листа будет изменено.
  3. Кодовое имя может использоваться только для
    листов в той же книге, что и код.
  4. Везде, где вы видите ThisWorkbook.Worksheets
    («имя листа»), вы можете заменить его кодовым именем рабочего листа.
  5. Вы можете использовать функцию SheetFromCodeName
    сверху, чтобы получить кодовое имя рабочих листов в других рабочих книгах.

 Активный лист

Объект ActiveSheet ссылается на рабочий лист, который в данный момент активен. Вы должны использовать ActiveSheet только в том случае, если у вас есть особая необходимость ссылаться на активный лист.

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

Если вы используете метод листа, такой как Range, и не
упоминаете лист, он по умолчанию будет использовать активный лист.

' Написать в ячейку A1 в активном листе
ActiveSheet.Range("A1") = 99

' Активный лист используется по умолчанию, если лист не используется
Range("A1") = 99

Объявление объекта листа

Объявление объекта листа полезно для того, чтобы сделать ваш
код более понятным и легким для чтения.

В следующем примере показан код для обновления диапазонов
ячеек. Первый Sub не объявляет объект листа. Вторая подпрограмма объявляет
объект листа, и поэтому код намного понятнее.

Sub NeObyavObektList()

    Debug.Print ThisWorkbook.Worksheets("Лист1").Name
    ThisWorkbook.Worksheets("Лист1").Range("A1") = 6
    ThisWorkbook.Worksheets("Лист1").Range("B2:B9").Font.Italic = True
    ThisWorkbook.Worksheets("Лист1").Range("B2:B9").Interior.Color = rgbRed

End Sub
Sub ObyavObektList()

    Dim sht As Worksheet
    Set sht = ThisWorkbook.Worksheets("Лист1")

    sht.Range("A1") = 6
    sht.Range("B2:B9").Font.Italic = True
    sht.Range("B2:B9").Interior.Color = rgbRed

End Sub

Вы также можете использовать ключевое слово With с объектом
листа, как показано в следующем примере.

Sub ObyavObektListWith()

    Dim sht As Worksheet
    Set sht = ThisWorkbook.Worksheets("Лист1")

    With sht
        .Range("A1") = 6
        .Range("B2:B9").Font.Italic = True
        .Range("B2:B9").Interior.Color = rgbRed
    End With

End Sub

Доступ к рабочему листу в двух словах

Из-за множества различных способов доступа к рабочему листу вы можете быть сбитыми с толку. Так что в этом разделе я собираюсь разбить его на простые термины.

  1. Если вы хотите использовать тот лист, который активен в данный момент, используйте ActiveSheet.
ActiveSheet.Range("A1") = 55

2. Если лист находится в той же книге, что и код, используйте кодовое имя.

3. Если рабочая таблица находится в другой рабочей книге, сначала получите рабочую книгу, а затем получите рабочую таблицу.

' Получить рабочую книгу
Dim wk As Workbook
Set wk = Workbooks.Open("C:ДокументыСчета.xlsx", ReadOnly:=True)
' Затем получите лист
Dim sh As Worksheet
Set sh = wk.Worksheets("Лист1")

Если вы хотите защитить пользователя от изменения имени листа, используйте функцию SheetFromCodeName из раздела «Имя кода».

' Получить рабочую книгу
Dim wk As Workbook
Set wk = Workbooks.Open("C:ДокументыСчета.xlsx", ReadOnly:=True)

' Затем получите лист
Dim sh As Worksheet
Set sh = SheetFromCodeName("sheetcodename",wk)

Добавить рабочий лист

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

Когда вы добавляете рабочий лист, он создается с именем по умолчанию, например «Лист4». Если вы хотите изменить имя, вы можете легко сделать это, используя свойство Name.

В следующем примере добавляется новый рабочий лист и изменяется имя на «Счета». Если лист с именем «Счета» уже существует, вы получите сообщение об ошибке.

Sub DobavitList()

    Dim sht As Worksheet

    ' Добавляет новый лист перед активным листом
    Set sht = ThisWorkbook.Worksheets.Add
    ' Установите название листа
    sht.Name = "Счета"

    ' Добавляет 3 новых листа перед активным листом
    ThisWorkbook.Worksheets.Add Count:=3

End Sub

В предыдущем примере вы добавляете листы по отношению к
активному листу. Вы также можете указать точную позицию для размещения листа.

Для этого вам нужно указать, какой лист новый лист должен
быть вставлен до или после. Следующий код показывает вам, как это сделать.

Sub DobavitListPervPosl()

    Dim shtNew As Worksheet
    Dim shtFirst As Worksheet, shtLast As Worksheet

    With ThisWorkbook

        Set shtFirst = .Worksheets(1)
        Set shtLast = .Worksheets(.Worksheets.Count)

        ' Добавляет новый лист на первую позицию в книге
        Set shtNew = Worksheets.Add(Before:=shtFirst)
        shtNew.Name = "FirstSheet"

        ' Добавляет новый лист к последней позиции в книге
        Set shtNew = Worksheets.Add(After:=shtLast)
        shtNew.Name = "LastSheet"

    End With

End Sub

Удалить рабочий лист

Чтобы удалить лист, просто вызовите Delete.

Dim sh As Worksheet
Set sh = ThisWorkbook.Worksheets("Лист12")
sh.Delete

Excel отобразит предупреждающее сообщение при удалении листа. Если вы хотите скрыть это сообщение, вы можете использовать код ниже:

Application.DisplayAlerts = False
sh.Delete
Application.DisplayAlerts = True

Есть два аспекта, которые нужно учитывать при удалении таблиц.

Если вы попытаетесь получить доступ к рабочему листу после
его удаления, вы получите ошибку «Subscript out of Range», которую мы видели в
разделе «Доступ к рабочему листу».

Dim sh As Worksheet
Set sh = ThisWorkbook.Worksheets("Лист2")
sh.Delete

' Эта строка выдаст «Subscript out of Range», так как «Лист2» не существует
Set sh = ThisWorkbook.Worksheets("Лист2")

Вторая проблема — когда вы назначаете переменную листа. Если вы попытаетесь использовать эту переменную после удаления листа, вы получите ошибку автоматизации, подобную этой:

Run-Time error -21147221080 (800401a8′) Automation Error

Если вы используете кодовое имя рабочего листа, а не
переменную, это приведет к сбою Excel,
а не к ошибке автоматизации.

В следующем примере показано, как происходят ошибки автоматизации.

sh.Delete

' Эта строка выдаст ошибку автоматизации
Debug.Assert sh.Name

Если вы назначите переменную Worksheet действительному рабочему листу, он будет работать нормально.

sh.Delete

' Назначить sh на другой лист
Set sh = Worksheets("Лист3")

' Эта строка будет работать нормально
Debug.Assert sh.Name

Цикл по рабочим листам

Элемент «Worksheets» — это набор рабочих листов, принадлежащих рабочей книге. Вы можете просмотреть каждый лист в коллекции рабочих листов, используя циклы «For Each» или «For».

В следующем примере используется цикл For Each.

Sub CiklForEach()

    ' Записывает «Привет Мир» в ячейку A1 для каждого листа
    Dim sht As Worksheet
    For Each sht In ThisWorkbook.Worksheets
         sht.Range("A1") = "Привет Мир"
    Next sht 

End Sub

В следующем примере используется стандартный цикл For.

Sub CiklFor()
    
    ' Записывает «Привет Мир» в ячейку A1 для каждого листа
    Dim i As Long
    For i = 1 To ThisWorkbook.Worksheets.Count
         ThisWorkbook.Worksheets(i).Range("A1") = "Привет Мир"
    Next sht

End Sub

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

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

Sub NazvVsehStr()

    ' Печатает рабочую книгу и названия листов для
    ' всех листов в открытых рабочих книгах
    Dim wrk As Workbook
    Dim sht As Worksheet
    For Each wrk In Workbooks
        For Each sht In wrk.Worksheets
            Debug.Print wrk.Name + ":" + sht.Name
        Next sht
    Next wrk

End Sub

Использование коллекции листов

Рабочая книга имеет еще одну коллекцию, похожую на Worksheets под названием Sheets. Это иногда путает пользователей. Чтобы понять, в первую очередь, вам нужно знать о типе листа, который является диаграммой.

В Excel есть возможность создать лист, который является диаграммой. Для этого нужно:

  1. Создать диаграмму на любом листе.
  2. Щелкнуть правой кнопкой мыши на графике и выбрать «Переместить».
  3. Выбрать первый вариант «Новый лист» и нажмите «ОК».

Теперь у вас есть рабочая книга, в которой есть типовые листы и лист-диаграмма.

  • Коллекция «Worksheets » относится ко всем рабочим листам в рабочей книге. Не включает в себя листы типа диаграммы.
  • Коллекция Sheets относится ко всем листам, принадлежащим книге, включая листы типовой диаграммы.

Ниже приведены два примера кода. Первый проходит через все
листы в рабочей книге и печатает название листа и тип листа. Второй пример
делает то же самое с коллекцией Worksheets.

Чтобы опробовать эти примеры, вы должны сначала добавить лист-диаграмму в свою книгу, чтобы увидеть разницу.

Sub KollSheets()

    Dim sht As Variant
    ' Показать название и тип каждого листа
    For Each sht In ThisWorkbook.Sheets
        Debug.Print sht.Name & " is type " & TypeName(sht)
    Next sht

End Sub

Sub KollWorkSheets()

    Dim sht As Variant
    ' Показать название и тип каждого листа
    For Each sht In ThisWorkbook.Worksheets
        Debug.Print sht.Name & " is type " & TypeName(sht)
    Next sht

End Sub

Если у вас нет листов диаграмм, то использование коллекции Sheets — то же самое, что использование коллекции WorkSheets.

Заключение

На этом мы завершаем статью о Worksheet VBA. Я надеюсь, что было полезным.

Три наиболее важных элемента Excel VBA — это рабочие книги, рабочие таблицы, диапазоны и ячейки.

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

Make a particular worksheet visible using a macro in Excel.

This is called activating a worksheet and is rather easy to do.

Sections:

Activate Worksheet by Name

Activate Worksheet by Index Number

Notes

Activate Worksheet by Name

Let’s navigate to, activate, the worksheet called «Sheet2».

Worksheets("Sheet2").Activate

08008f3433d614b4eb713fdcde4e01eb.jpg

Worksheets(«Shee2») is how we reference the sheet to which we want to navigate.

Sheet2 is the name of the sheet to which we want to navigate. Make sure to surround it with double quotation marks.

Activate is what actually takes the user to that worksheet.

Putting it all together, we get: Worksheets(«Sheet2»).Activate

It’s as simple as that.

Activate Worksheet by Index Number

This time, let’s navigate to the second worksheet using its index number.

All we do is to replace «Sheet2» from the last example with 2.

Worksheets(2).Activate

3e8969b16e6f131afc29445b0f9a02ac.jpg

2 is the index number of the desired worksheet and Activate is what takes us to the desired worksheet.

This example can be confusing if you are not used to using index numbers, but index numbers are really helpful when you have to do something like loop through all of the worksheets in the workbook.

Notes

Basically, just reference the desired worksheet, however you want, and then type .Activate after it.

You should not use the Activate feature to navigate to a worksheet so that you can get data from it or put data into it. This is very bad Macro/VBA design and it will make your life hell later on. To get data from separate worksheets, read this tutorial: Select Data from Separate Worksheets with Macros VBA in Excel.

This feature should be used when you want the user to end up on a specific worksheet.

Make sure to download the sample file attached to this tutorial so that you can see this macro in Excel and work with it.

Similar Content on TeachExcel

Copy and Paste Data using Macro VBA in Excel

Tutorial: How to copy and paste data using a Macro in Excel. I’ll show you multiple ways to do this,…

Select Data from Separate Worksheets with Macros VBA in Excel

Tutorial: Select data from other worksheets with Macros and VBA without navigating to those workshee…

Get the Last Row using VBA in Excel

Tutorial:
(file used in the video above)
How to find the last row of data using a Macro/VBA in Exce…

Login to a Website using a Macro

: Connect and login to a website using a macro in Excel.
This allows you to open a website a…

Get the Name of a Worksheet in Macros VBA in Excel

Tutorial: How to get the name of a worksheet in Excel using VBA and Macros and also how to store tha…

Guide to Creating Charts with a Macro in Excel

Tutorial: How to add, edit, and position charts in Excel using VBA.
This tutorial covers what to do …

Subscribe for Weekly Tutorials

BONUS: subscribe now to download our Top Tutorials Ebook!

 

SergKh

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

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

#1

01.08.2018 12:59:02

Выполнение последней строки ниже в 64-разрядной среде вызывает ошибку

Run-time error ‘9’:
Subscript out of range

Код
Private Sub Имя()

Dim dtLast_day As Date
Dim strFileName As String, strFilePath As String, strFullFileName As String
Dim strFilePath_i As String, strSheetName  As String
Dim l As Integer
    strFilePath = "K:UPKпуть..."
    Workbooks("Сбор статистики авт.").Sheets("Дата актуальности").Activate


В 32-разрядной среде все нормально (открывается ОДИН и ТОТ же сетевой файл). Почему это — здесь нет ни Declare, ни Long, которые надо редактировать для 64-разрядной среды ???

Изменено: SergKh01.08.2018 22:45:54

 

skais675

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

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

Быть может стоит указать и расширение книги.

 

vikttur

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

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

Код в сообщении нужно оформлять с помощью кнопки <…>

 

SergKh

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

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

skais675, у книги нет расширения. Расширение есть у файлов. Но я тем не менее попробовал и конечно не помогло.

vikktur, исправил.

Изменено: SergKh01.08.2018 15:01:20

 

sokol92

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

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

#5

01.08.2018 15:13:13

Цитата
SergKh написал:
у книги нет расширения

Проверьте. Откройте любую книгу и выполните макрос

Код
Sub test()
  MsgBox ActiveWorkbook.Name
End Sub

Пример из #1 не понятен. В строке 8 активируется книга, открытие которой не показано.
В названии темы упоминание о 64-разрядной среде не при чем.

Владимир

 

skais675

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

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

#6

01.08.2018 16:06:56

SergKh

Ну до кучи укажите тогда уже и полный путь+файл+расширение.
Ну а также рекомендовал бы сначала

Код
Workbooks("...").Activate

а потом

Код
Sheets("...").Select.

И стало бы ясно в чем проблема.

Изменено: skais67501.08.2018 16:14:30

Мой канал

 

Hugo

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

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

А Sheets(«…»).Select может и не сработать… и не по причине отсутствия такого листа. Кстати, в теме опять нет примера…

 

SergKh

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

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

sokol92, skais675, вы совершенно правы с именем книги, причина именно в отсутствии расширения. Проблема РЕШЕНА, ОГРОМНОЕ СПАСИБО!

Но только в Office16 похоже расширение является обязательным (и показывается командой MsgBox ActiveWorkbook.Name), его отсутствие вызывает ошибку, а в Office10 — нет (и не обязательно, и не показывается командой MsgBox ActiveWorkbook.Name, поэтому я так и заявил поначалу, и ошибок нет). Вот и получилось — файл работал около года на Office10, но только неделю назад пришлось перейти на Office16 и …

Так что название темы действительно можно поменять, только не знаю как.

Еще раз ОГРОМНОЕ СПАСИБО!

 

skais675

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

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

#9

01.08.2018 16:21:38

Цитата
Hugo написал:
А Sheets(«…»).Select может и не сработать… и не по причине отсутствия такого листа.

Если книга активирована и он видим, и имя верно, тогда почему?

Мой канал

 

skais675

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

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

SergKh

, как же Вы пробовали в #4, что потом получилось в #8?

Изменено: skais67501.08.2018 16:23:41

 

Hugo

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

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

skais675,  если код в модуле другой книги. Именно книги, а не в стандартном. А как там по факту — никому неизвестно…
Это если писать раздельно, как Вы подсказали, без явного указания родителя.

 

skais675

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

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

Hugo

Я ж написал активируем книгу а потом select листа.

Изменено: skais67501.08.2018 16:29:46

 

Hugo

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

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

Проверили? Ну ведь точно не проверяли :)

Изменено: Hugo01.08.2018 16:33:58

 

skais675

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

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

#14

01.08.2018 16:42:08

Цитата
Hugo написал:
Проверили? Ну ведь точно не проверяли

Проверил, все как я и говорил — не понимаю Вас?
Вот пример:

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

  • test2.xlsx (8.3 КБ)
  • test1.xlsm (17.09 КБ)

Изменено: skais67501.08.2018 16:49:53

Мой канал

 

Hugo

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

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

#15

01.08.2018 16:49:58

Цитата
skais675 написал:
не понимаю Вас?
Цитата
Hugo написал:
если код в модуле другой книги. Именно книги, а не в стандартном.
 

skais675

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

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

Попробовал и в модуль книги, тоже открыл как следует но выдал сообщение «400».

Hugo

Вы бы уже пояcнили почему происходит эта ошибка?

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

  • test2.xlsx (8.3 КБ)
  • test1.xlsm (18.72 КБ)

Изменено: skais67501.08.2018 22:44:23

 

SergKh

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

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

skais675

на вопрос #10. Первый раз наверное ошибку при проверке допустил, вот и не помогло, то же самое сообщение вылезло. Но когда увидел что написал MsgBox, уже очень внимательно перепроверил. Остальные после #10 вопросы похоже не ко мне, так что не отвечаю.  

 

Hugo

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

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

Потому что код из модуля ЭтаКнига будет искать лист у себя, а не в активной книге.
Точно так же как и код из модуля листа ищет диапазоны только у себя.
Это всё если нет точного указания родителя.

 

skais675

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

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

#19

01.08.2018 16:59:04

Hugo

однако макрос из модуля книги все делает и лист выделяет из другой книги все как нужно , но вот сообщение выдает. Потому

Цитата
Hugo написал:
Потому что код из модуля ЭтаКнига будет искать лист у себя, а не в активной книге.Точно так же как и код из модуля листа ищет диапазоны только у себя.

не соответствует действительности.
файлы в #17

Изменено: skais67501.08.2018 17:00:39

Мой канал

 

Дмитрий(The_Prist) Щербаков

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

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

Профессиональная разработка приложений для MS Office

#20

01.08.2018 17:05:03

Цитата
skais675 написал:
не соответствует действительности

Соответствует. Мат.часть вещь упрямая и непоколебимая :)
Если Вы в модуле ЭтаКнига пишите Sheets, то эта коллекция по умолчанию относится к той книге, в модуле которой это написано. Т.к. сначала коллекции и методы определяются для модуля класса, в котором записан код.
Если же записать Workbooks(«бла-бла.xls»).Sheets(«name») — то ошибки это не вызовет, т.к. явно указано из какой книги брать коллекцию Sheets.
И еще раз уточним: именно при записи в модуле ЭтаКнига(thisWorkbook). В случае со стандартными модулями коллекции и свойства будут определены для активной книги.

Изменено: Дмитрий(The_Prist) Щербаков01.08.2018 17:05:54

Даже самый простой вопрос можно превратить в огромную проблему. Достаточно не уметь формулировать вопросы…

 

Hugo

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

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

#21

01.08.2018 17:06:06

Цитата
skais675 написал:
из модуля книги все делает и лист выделяет

— у меня он даже книгу не открывает, ну да это ладно.
Ну а про выделение листа — Вы не пробовали книгу сохранить с другим активным листом? :)

 

Дмитрий(The_Prist) Щербаков

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

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

Профессиональная разработка приложений для MS Office

#22

01.08.2018 17:09:25

Цитата
skais675 написал:
файлы в #17

там даже путь к открываемой книге не указан :) Следовательно если книга 2 не по тому пути, который для Excel является умолчанием — уже ошибка. Но и без этого все равно выдает ошибку на строке Sheets(«Sheet2»).Select, т.к. активна книга test2, а метод Select пытаетесь выполнить для листа книги test1(той, в которой код). Я сейчас про процедуру tt2.

Изменено: Дмитрий(The_Prist) Щербаков01.08.2018 17:10:09

Даже самый простой вопрос можно превратить в огромную проблему. Достаточно не уметь формулировать вопросы…

 

sokol92

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

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

Модераторам: Название темы. Как правильно ссылаться на открытую книгу Excel и листы книги в коде VBA

Изменено: sokol9201.08.2018 18:44:54

 

skais675

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

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

#24

01.08.2018 19:30:30

Hugo,
Дмитрий(The_Prist) Щербаков

Все верно, невнимателен был с примером

Цитата
Hugo написал:
Вы не пробовали книгу сохранить с другим активным листом?

Спасибо за разъяснения!

Мой канал

 

RAN

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

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

#25

01.08.2018 20:08:40

Цитата
SergKh написал:
Но только в Office16 похоже расширение является обязательным (и показывается командой MsgBox ActiveWorkbook.Name), его отсутствие вызывает ошибку, а в Office10 — нет (и не обязательно, и не показывается командой MsgBox ActiveWorkbook.Name, поэтому я так и заявил поначалу, и ошибок нет). Вот и получилось — файл работал около года на Office10, но только неделю назад пришлось перейти на Office16 и …

Необходимость указывать расширение определяется настройкой системы «скрывать расширения зарегистрированных типов файлов».
На 2016 не пробовал, а в 2010 точно так.
При этом обращение идет к первому файлу с таким именем из коллекции Workbooks (который был открыт раньше).

Обращение макроса к активному листу

Влад777

Дата: Среда, 01.07.2015, 15:02 |
Сообщение № 1

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

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

Сообщений: 61


Репутация:

0

±

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


Excel 2007

Добрый день! Есть такой макрос.

[vba]

Код

Windows(«Приложение 1_код 39.xlsx»).Activate
Sheets(«ПРИЛОЖЕНИЕ 1»).Select
  Set c = Columns(2).Find(«*», searchdirection:=xlPrevious)
    If c Is Nothing Then
       Cells(1, 2).Select
    Else
       c.Offset(1, 0).Select
    End If
     ActiveCell.FormulaR1C1 = «=[Книга3.xlsm]Лист1!R2C79»
    iRow = Columns(«B»).Find(What:=»*», LookIn:=xlValues, searchdirection:=xlPrevious, SearchOrder:=xlByRows).Row
     Selection.Copy
     Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
         :=False, Transpose:=False

[/vba]

Как сделать так, чтобы он обращался не к конкретному листу «Лист1» файла «Книга3.xlsm», а просто к активному листу данного файла безотносительно его наименования?

 

Ответить

KSV

Дата: Среда, 01.07.2015, 15:09 |
Сообщение № 2

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

Ранг: Ветеран

Сообщений: 770


Репутация:

255

±

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


Excel 2013

Добрый день!
[vba]

Код

ActiveCell.FormulaR1C1 = «=R2C79»

[/vba]


KSV.VBA@gmail.com
Яндекс.Деньги: 410011921213333

 

Ответить

Макрописец

Дата: Среда, 01.07.2015, 15:14 |
Сообщение № 3

Группа: Заблокированные

Ранг: Форумчанин

Сообщений: 128


Репутация:

7

±

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


Excel 2010

Или так:
[vba]

Код

Windows(«Приложение 1_код 39.xlsx»).Activate
With ActiveSheet
Set c = Columns(2).Find(«*», searchdirection:=xlPrevious)
       If c Is Nothing Then
       Cells(1, 2).Select
       Else
       c.Offset(1, 0).Select
       End If
       ActiveCell.FormulaR1C1 = «=[Книга3.xlsm]Лист1!R2C79»
       iRow = Columns(«B»).Find(What:=»*», LookIn:=xlValues, searchdirection:=xlPrevious, SearchOrder:=xlByRows).Row
       Selection.Copy
       Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
           :=False, Transpose:=False
End With

[/vba]


ТЕРПЕНИЕ И ТРУД — ВСЁ ПЕРЕТРУТ!

Сообщение отредактировал МакрописецСреда, 01.07.2015, 15:15

 

Ответить

Влад777

Дата: Среда, 01.07.2015, 15:22 |
Сообщение № 4

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

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

Сообщений: 61


Репутация:

0

±

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


Excel 2007

KSV,
[vba]

Код

ActiveCell.FormulaR1C1 = «=R2C79»

[/vba]

Такой вариант не подходит — макрос не видит к какому файлу надо обращаться. Необходимо сохранить отсылку к файлу Книга3.

 

Ответить

SkyPro

Дата: Среда, 01.07.2015, 15:27 |
Сообщение № 5

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

Ранг: Старожил

Сообщений: 1206


Репутация:

255

±

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


2010

Ну так обращайтесь к файлу. В чем проблема? Можно в начале макроса вообще сделать так:
[vba]

Код

Dim wb: Set wb = workbooks(«Приложение 1_код 39»)
wb.Activate
Debug.Print ActiveWorkbook.Name
Debug.Print ActiveSheet.Name
Debug.Print ActiveCell.Address

[/vba]


skypro1111@gmail.com

Сообщение отредактировал SkyProСреда, 01.07.2015, 15:28

 

Ответить

Влад777

Дата: Среда, 01.07.2015, 15:29 |
Сообщение № 6

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

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

Сообщений: 61


Репутация:

0

±

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


Excel 2007

Макрос в файле Приложение 1…копирует ячейку из файла Книга 3. Мне необходимо чтобы он копировал не из конкретного листf, а просто из активного листа…

 

Ответить

Влад777

Дата: Среда, 01.07.2015, 15:33 |
Сообщение № 7

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

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

Сообщений: 61


Репутация:

0

±

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


Excel 2007

SkyPro, Как в таком случае будет выглядеть строчка?

[vba]

Код

  ActiveCell.FormulaR1C1 = «=[Книга3.xlsm]Лист1!R2C79»

[/vba]

В ней и проблема…Мне надо избавится от «Лист1» и заменить на просто активный лист….

 

Ответить

Manyasha

Дата: Среда, 01.07.2015, 15:35 |
Сообщение № 8

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

Ранг: Старожил

Сообщений: 2198


Репутация:

898

±

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


Excel 2010, 2016

Влад777, да без разницы какая книга, Вам просто показали, как получить ее имя и имя активного листа.
Так подойдет?[vba]

Код

Set wb3 = Workbooks(«Книга3.xlsm»)
shName = wb3.ActiveSheet.Name
ActiveCell.FormulaR1C1 = «=[» & wb3.Name & «]» & shName & «!R2C1»

[/vba]


ЯД: 410013299366744 WM: R193491431804

Сообщение отредактировал ManyashaСреда, 01.07.2015, 15:36

 

Ответить

RAN

Дата: Среда, 01.07.2015, 15:37 |
Сообщение № 9

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

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

Сообщений: 5645

[vba]

Код

ActiveCell.FormulaR1C1 = «=[» & ActiveWorkbook.Name & «]» & «ActiveSheet.Name» & «!R2C79»

[/vba]


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

 

Ответить

Влад777

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

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

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

Сообщений: 61


Репутация:

0

±

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


Excel 2007

Manyasha, Большое спасибо…все хорошо работает…

 

Ответить

Макрописец

Дата: Среда, 01.07.2015, 16:05 |
Сообщение № 11

Группа: Заблокированные

Ранг: Форумчанин

Сообщений: 128


Репутация:

7

±

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


Excel 2010

Влад777,
А мой вариант?


ТЕРПЕНИЕ И ТРУД — ВСЁ ПЕРЕТРУТ!

 

Ответить

Влад777

Дата: Четверг, 02.07.2015, 09:47 |
Сообщение № 12

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

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

Сообщений: 61


Репутация:

0

±

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


Excel 2007

Макрописец, добрый день…

Ваш вариант все равно обращается к конкретному листу «Лист1». Именно в этой строчке у меня и была проблема….Как раз, ее и исправила мне Manyasha.

 

Ответить

Макрописец

Дата: Четверг, 02.07.2015, 10:52 |
Сообщение № 13

Группа: Заблокированные

Ранг: Форумчанин

Сообщений: 128


Репутация:

7

±

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


Excel 2010

Влад777,
Ну я уже понял.


ТЕРПЕНИЕ И ТРУД — ВСЁ ПЕРЕТРУТ!

 

Ответить

Like this post? Please share to your friends:
  • Vba excel ссылка на таблицу
  • Vba excel ссылка на столбец
  • Vba excel ссылка на сайт
  • Vba excel ссылка на процедуру
  • Vba excel ссылка на активный лист