Последние записи
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
20th
Дек
Поиск и копирование совпадений на нескольких листах
Posted by obzor under VBA
Как произвести копирование нескольких ячеек (наименование, кофицент, количество) из листа «Temp» на лист «Смета» только если значение ячейки «Temp».C#(наименование) найдено на листе «Прайс-лист».A:A (наименование)
Интересует пример макросом VBA, впр и индекс\поискпоз — не подходят…
- Temp — Лист с временными данными.
- Смета — лист где должны проводится расчеты
- Прайс лист — База номенклатуры по которой будет проводится расчет.
Sub Macros()
Dim sh As Worksheet, sh2 As Worksheet, sh3 As Worksheet
Dim rng As Range, i As Long, j As Long, r As Long, sh2r As Long
Set sh = Sheets("Temp")
Set sh2 = Sheets("Прайс-Лист")
Set sh3 = Sheets("Смета")
' строк в прайсе
sh2r = sh2.Cells(sh2.Rows.Count, 1).End(xlUp).Row
With sh
' перебираем елементы С на темпе
For i = 2 To .Cells(.Rows.Count, 3).End(xlUp).Row
' сравниваем со списком листа Прайс-Лист
For j = 1 To sh2r
' найдено совпадение
If sh2.Cells(j, "A") = .Cells(i, "C") Then
' последняя строка Сметы
r = sh3.Cells(sh3.Rows.Count, 1).End(xlUp).Row + 1
' перенос значений на смету
.Range(.Cells(i, "C"), .Cells(i, "E")).Copy _
sh3.Cells(r, "A")
' перенос цены на смету
sh3.Cells(r, "D") = sh2.Cells(j, "B")
' выход из цикла
Exit For
End If
Next j
Next
End With
Set sh = Nothing
Set sh2 = Nothing
Set sh3 = Nothing
End Sub
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)