VBA Excel
242 subscribers
88 photos
23 links
VBA Excel для начинающих. Справка по VBA Excel. Visual Basic for Applications. Справочник. Самоучитель.
Download Telegram
🔥 Свойство Offset объекта Range

Свойство Range.Offset позволяет перемещать диапазон относительно указанной ячейки на заданное количество строк и столбцов. Это свойство полезно, когда нужно динамически манипулировать ячейками или диапазонами без явного указания их адресов.

📌 Примеры:

1️⃣ Переместить ссылку на ячейку на 2 строки вниз и 1 столбец вправо от A1:
Range("A1").Offset(2, 1).Select  


🔹 Это выберет ячейку B3, так как смещение на 2 строки вниз и 1 столбец вправо от A1 даёт B3.

2️⃣ Изменить значение ячейки, которая находится на 3 строки вверх и 2 столбца влево от D5:
Range("D5").Offset(-3, -2).Value = "Hello"  


🔹 В ячейке B2 будет установлено значение "Hello", так как смещение на -3 строки вверх и -2 столбца влево даёт B2.

3️⃣ Использование Offset для работы с диапазонами:
Range("A1").Offset(1, 0).Resize(5, 1).Value = "Text"  


🔹 Устанавливает текст "Text" в ячейки A2:A6, смещая на 1 строку вниз от A1 и сужая диапазон до 5 строк.

4️⃣ Создание цикла для перебора ячеек в столбце с динамическим смещением:
Dim i As Integer  
For i = 1 To 5
Range("A1").Offset(i, 0).Value = "Row " & i
Next i


🔹 В столбце A появится текст "Row 1", "Row 2", и так далее до "Row 5".

💡 Важно:
Offset возвращает новый диапазон, поэтому его можно использовать для получения или изменения данных в смещённых ячейках.

#VBA #ExcelVBA #Range #Offset