Последние записи
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
- wprintf как напечатать кириллицу
- Взаимодействие через командную строку
Интенсив по 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 (Компьютерное железо)