Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/34: Рейтинг темы: голосов - 34, средняя оценка - 4.62
0 / 0 / 0
Регистрация: 09.06.2016
Сообщений: 26

Макрос сравнения двух столбцов с условиями

09.06.2016, 09:22. Показов 6807. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
есть 5 столбцов в виде
1300.00900900180.00
3800.009029010.00
4402.00903902268.00
5231.009059030.00
6350.00906906309.00
7261.009079070.00
надо сравнить третий с четвертым(могут быть любые два последовательных столбца) с условиями:
1- если оба равный переходим к следующей строке
2- если в третьем есть а в четвертом нет то в четвертый и все последующие столбцы вставляем пустые ячейки со смещением вниз
3- если в четвертом есть а в третьем нет то ко всем ячейкам до третей включительно вставляем пустые ячейки со смещением вниз
4- если оба пустые переходим к следующей строке при двукратном повторении останавливаем макрос

результат выполнения макроса
1300.00900900180.00
   9010.00
3800.00902902268.00
4402.009039030.00
5231.00905  
6350.00906906309.00
7261.00907  
   9080.00
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.06.2016, 09:22
Ответы с готовыми решениями:

Макрос сравнения двух таблиц
Здравствуйте,помогите сравнить два файла есть файл с эталонной таблицей и файл для сравнения, надо сравнить столбец адреса с эталоном и...

Макрос сравнения двух таблиц
Здравствуйте,помогите сравнить два файла есть файл с эталонной таблицей и файл для сравнения, надо сравнить столбец адреса с эталоном и...

Макрос сравнения содержимого двух ячеек
Простите за столь простой вопрос Есть: в листе exel при изменении даты в ячейке с2 и нажатии ентр, меняется дата в к1 и происходит...

6
 Аватар для KoGG
5646 / 1628 / 418
Регистрация: 23.12.2010
Сообщений: 2,450
Записей в блоге: 1
09.06.2016, 12:07
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Sub Выравнивание()
    Dim i&, k&
    Do
        i = i + 1
        If Cells(i, 3) > Cells(i, 4) And Cells(i, 4) > 0 Then
            Cells(i, 1).Resize(1, 3).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        ElseIf Cells(i, 3) < Cells(i, 4) And Cells(i, 3) > 0 Then
             Cells(i, 4).Resize(1, 2).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        ElseIf Trim(Cells(i, 3)) & Trim(Cells(i, 4)) = "" Then
            k = k + 1
            If k > 1 Then Exit Do
        Else
            k = 0
        End If
    Loop
End Sub
0
0 / 0 / 0
Регистрация: 09.06.2016
Сообщений: 26
09.06.2016, 13:38  [ТС]
Спасибо огромное

Добавлено через 49 минут
код не выполняет условие
2- если в третьем есть а в четвертом нет то в четвертый и все последующие столбцы вставляем пустые ячейки со смещением вниз
он только две ячейки вниз смещает
0
 Аватар для KoGG
5646 / 1628 / 418
Регистрация: 23.12.2010
Сообщений: 2,450
Записей в блоге: 1
09.06.2016, 14:15
У меня на данном примере получилось точно то, что требовалось (если еще поменять D7 на 908).

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

Немного переделал для работы с пустыми ячейками, но может быть все равно неправильно, так как подобран плохой пример.
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
Sub Выравнивание()
    Dim i&, k&, LastRow
    LastRow = .Cells(.Rows.Count, 1).End(xlUp).Row
    Do Until i > LastRow
        i = i + 1
        If Cells(i, 3) > Cells(i, 4) Then
            Cells(i, 1).Resize(1, 3).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
            LastRow = LastRow + 1
        ElseIf Cells(i, 3) < Cells(i, 4) Then
            Cells(i, 4).Resize(1, 2).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
            LastRow = LastRow + 1
        ElseIf Trim(Cells(i, 3)) & Trim(Cells(i, 4)) = "" Then
            k = k + 1
            If k > 1 Then Exit Do
        Else
            k = 0
        End If
    Loop
End Sub
Если вместо некоторых чисел у Вас стоит текст, макрос будет работать неправильно.
0
0 / 0 / 0
Регистрация: 09.06.2016
Сообщений: 26
09.06.2016, 14:35  [ТС]
выдает ошибку
Compile error:
invalid or unqualified reference

LastRow = .Cells(.Rows.Count, 1).End(xlUp).Row

Добавлено через 4 минуты
общая структура таблицы вот такая
 235,381121711217892306.0037В наличии1
 346,341126211262893450.0037В наличии1
 408,571126311263894531.0037В наличии1
 207,731131711311895268.0008Предзаказ1
 73,1 1132011317896325.0037В наличии1
 73,1 11321113198970.00 08Предзаказ0
0
 Аватар для KoGG
5646 / 1628 / 418
Регистрация: 23.12.2010
Сообщений: 2,450
Записей в блоге: 1
09.06.2016, 14:43
Лучший ответ Сообщение было отмечено vikkrsk как решение

Решение

Visual Basic
1
LastRow = Cells(Rows.Count, 1).End(xlUp).Row
- однако второй вариант впадает в бесконечный цикл со 2-м набором данных.
Первый вариант работал правильно, чтобы смещал больше столбцов:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Sub Выравнивание1()
    Dim i&, k&
    Do
        i = i + 1
        If Cells(i, 3) > Cells(i, 4) And Cells(i, 4) > 0 Then
            Cells(i, 1).Resize(1, 3).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        ElseIf Cells(i, 3) < Cells(i, 4) And Cells(i, 3) > 0 Then
             Cells(i, 4).Resize(1, 6).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        ElseIf Trim(Cells(i, 3)) & Trim(Cells(i, 4)) = "" Then
            k = k + 1
            If k > 1 Then Exit Do
        Else
            k = 0
        End If
    Loop
End Sub
1
0 / 0 / 0
Регистрация: 09.06.2016
Сообщений: 26
09.06.2016, 15:09  [ТС]
все работает,спасибо, а сможешь помочь еще вот с этой задачкой Макрос проверки столбцов с заменой значений
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.06.2016, 15:09
Помогаю со студенческими работами здесь

Макрос для сравнения двух дат
1) Пишу макрос для EXCEL как сравнить две даты ? 2) Как узнать какая дата будет если от NOW() сместится на 5 дней ниже: а не самому...

Код сравнения двух разных столбцов
нужна помощь к коде есть сравнения двух столбцов на разных столбцов но ну меня ошибка 9 помогите Private Sub...

Макрос для сравнения данных в двух столбцах, вместо vlookup
Подскажите, пожалуйста, как написать макрос, который бы можно было использовать для сравнения данных в двух столбцах, вместо vlook up.

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

Макрос на сравнение двух столбцов
Всем добрый вечер. Помогите пожалуйста с макросом на сравнение двух столбцов, после чего он находит одинаковые числа и складывает их. Проще...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru