
Последние записи
- Как из ip адреса вывести последние цифры
- Вставка символа Unicode в RichEdit в Delphi 7
- Как поменять иконки все папок Windows 11 со стандартной желтой на свою?
- WinIO для чтения/записи портов I/O и физической памяти
- Delphi: Вывести N директорий в заданной (без рекурсии вложенных папок)
- Дополнительные кнопки мышки
- Курсы программистов. Стоит ли?
- Удаление одинаковых строк
- Создание потоков в процессе
- Вывод на печать графического файла

Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk

Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
9th
Ноя
Копирование данных «отталкиваясь» от последней заполненной строки Excel
Posted by obzor under VBA
Задача казалось бы легкая есть данные (для примера в столбцах A:G) и нужно скопировать данные одной строки и вставить в определенную-другую строку этого же листа в диапазон например H:N или O:U и тд.
Трудность заключается в том что строки каждый день добавляются и для работы макросу нужно «отталкиваться» от последней строки с данными(снизу) поэтому прошу помочи разобраться как это сделать.
Для примера я выбрал пару действий чтоб понять сам принцип.. допустим надо:
с пред-пред-предпоследней строки (в примере 7-я строка) скопировать A:G и вставить в пред-предпоследнюю (в примере 8-я) в H:N
с пред-предпоследней строки (8-я) скопировать A:G и вставить в предпоследнюю (9-я) в H:N
с пред-пред-пред-предпоследней строки (6-я) скопировать A:G и вставить в пред-пред-предпоследнюю (7-я) в O:U
с пред-пред-предпоследней строки (7-я) скопировать A:G и вставить в предпоследнюю (9-я) в O:U
rowsCount = Cells(Rows.Count, "A").End(xlUp).Row
Sub CopyMyRange()
Dim LastRow As Integer
Dim upOffset As Byte
Dim rowNumber As Integer
Dim rngFrom As Range
LastRow = Cells(Rows.Count, "A").End(xlUp).Row
upOffset = CInt(InputBox("Введите количество строк для отступа с конца", "парамерт 1", 2))
rowNumber = Application.WorksheetFunction.Max(1, LastRow - upOffset)
Set rngFrom = Range("A" & rowNumber & ":G" & rowNumber)
rngFrom.Copy
upOffset = CInt(InputBox("Введите количество строк c конца для вставки", "парамерт 1", 2))
rowNumber = Application.WorksheetFunction.Max(1, LastRow - upOffset)
With Cells(rowNumber, "H")
.PasteSpecial Paste:=xlPasteAllUsingSourceTheme, Operation:=xlNone _
, SkipBlanks:=False, Transpose:=False
.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
:=False, Transpose:=False
End With
End Sub
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту

пеллетные котлы

Пеллетный котел Emtas

Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)