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

Поиск уникальных значений в динамическом массиве с переносом их другой лист

30.08.2021, 12:12. Показов 4449. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день ГУРУ. Есть задачка, всю голову сломал. Без ВАС ни как не обойтись
Есть лист "Плейлист" куда будут копироваться значения из входящих файлов (как в примере) там будут пустые ячейки. Что требуется, есть лист "Уникальные значения" нужно: при внесении значений на лист "Плейлист" в столбец B, формула копирует эти значения в столбец B на листе "Уникальные значения", но при этом автоматически удаляет, при копирование, неуникальные значения сравнивая со столбцом A. При внесение данных в столбец C, сравнение на уникальностью значений происходит со столбцами A и В и так далее.

Очень нужна ваша помощь
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.08.2021, 12:12
Ответы с готовыми решениями:

Поиск ячейки и копирование связанных с ней ячеек с переносом на другой лист
Добрый день! С утра мучаюсь с этой задачей. На работе постоянно приходится делать отчет. Сотрудников порядка 100, поэтому хотелось бы...

Поиск уникальных значений по диапазону, суммирование количества и добавление суммы на сводный лист
Доброго времени, Есть количество уникальных значений на Листе1 , нужно найти эти значения на Листе2, посчитать общее количество и...

Поиск уникальных значений в массиве
Доброго времени суток, уважаемые форумчане. Подскажите как лучше через vba реализовать вот такую задачу. На листе 1 В колонке...

15
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 65
30.08.2021, 12:16  [ТС]
забыл пример. И вопрос это можно реализовать формулами?
Вложения
Тип файла: xlsx Феникс пример.xlsx (74.5 Кб, 30 просмотров)
0
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 65
30.08.2021, 12:32  [ТС]
получается, что на листе "Плейлист" формируется массив значений от A6S600, при внесение значений в столбы, происходит копирование в соответствующий столбец на листе "Уникальные значения", проверкой уникальных значений во всех предыдущих столбцах и убирает не уникальные значения в копируемом столбце.
0
 Аватар для KoGG
5643 / 1625 / 418
Регистрация: 23.12.2010
Сообщений: 2,440
Записей в блоге: 1
30.08.2021, 16:03
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
Sub Копировать_уникальные()
    Dim i&, j&, LastRow&, Dic As Object, A, B, S
    With Worksheets("Плейлист")
        LastRow = .UsedRange.Rows.Count
        A = .Range("A6:DS" & LastRow).Value
    End With
    ReDim B(1 To UBound(A), 1 To UBound(A, 2))
    Set Dic = CreateObject("Scripting.Dictionary")
    Dic.CompareMode = 1
    With Worksheets("Уникальные значение") ' или With Worksheets("иникальные значение") '- в файле примера
        .UsedRange.Offset(1, 0).ClearContents
        For i = 1 To UBound(A)
            For j = 1 To UBound(A, 2)
                S = Trim(A(i, j))
                If S <> "" Then
                    If Not Dic.Exists(S) Then
                        Dic(S) = 0&
                        B(i, j) = S
                    End If
                End If
            Next j
        Next i
        .Range("A2").Resize(UBound(B), UBound(B, 2)) = B
    End With
End Sub
Добавлено через 22 минуты
Правильная последовательность обхода по столбцам:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
Sub Копировать_уникальные()
    Dim i&, j&, LastRow&, Dic As Object, A, B, S
    With Worksheets("Плейлист")
        LastRow = .UsedRange.Rows.Count
        A = .Range("A6:DS" & LastRow).Value
    End With
    ReDim B(1 To UBound(A), 1 To UBound(A, 2))
    Set Dic = CreateObject("Scripting.Dictionary")
    Dic.CompareMode = 1
    With Worksheets("Уникальные значение") ' или With Worksheets("иникальные значение") '- в файле примера
        .UsedRange.Offset(1, 0).ClearContents
        For j = 1 To UBound(A, 2)
            For i = 1 To UBound(A)
                S = Trim(A(i, j))
                If S <> "" Then
                    If Not Dic.Exists(S) Then
                        Dic(S) = 0&
                        B(i, j) = S
                    End If
                End If
            Next i
        Next j
        .Range("A2").Resize(UBound(B), UBound(B, 2)) = B
    End With
End Sub
0
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 65
30.08.2021, 16:50  [ТС]
спасибо. Но макрос убирает со всего листа не уникальные значения, а у меня затык в том, чтобы это делать:
Из столбца В убрать все значения которые есть в А
Из столбца С убрать все значения которые есть в диапазоне А:В
Из столбца В убрать все значения которые есть в диапазоне А:С
и т.д. А если бы он еще убирал пустоты ячейки так в столбце так вообще огонь
0
 Аватар для KoGG
5643 / 1625 / 418
Регистрация: 23.12.2010
Сообщений: 2,440
Записей в блоге: 1
30.08.2021, 16:57
Все что описано, макрос делает (пустые уберу отдельно).
Возможная разница:
Если работаем со столбцом С и там есть 2 повторяющихся значения, отсутствующих в столбцах А:В, мы должны сохранить в с столбце 2 значения ? Сейчас сохраняется только 1.
0
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 65
30.08.2021, 17:01  [ТС]
проверил, получается в столбце А все уникальные значения изначальна, а из них убираются значения которые есть в столбце В
0
 Аватар для KoGG
5643 / 1625 / 418
Регистрация: 23.12.2010
Сообщений: 2,440
Записей в блоге: 1
30.08.2021, 17:07
Пункт:
Из столбца В убрать все значения которые есть в диапазоне А и С - не реализован, он не описан в изначальном условии.
0
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 65
30.08.2021, 17:08  [ТС]
Простите, все работает, второй код супер, это чудо.
Скажите, значения оно стирает на листе "Уникальные значения" со второй строки, я могу поправить в коде?
0
 Аватар для KoGG
5643 / 1625 / 418
Регистрация: 23.12.2010
Сообщений: 2,440
Записей в блоге: 1
30.08.2021, 17:11
Надо копировать второй макрос, он не убирает в столбце А значения столбцов B:C.

Добавлено через 2 минуты
Чтобы не было пустот:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
Sub Копировать_уникальные()
    Dim i&, j&, k&, LastRow&, Dic As Object, A, B, S
    With Worksheets("Плейлист")
        LastRow = .UsedRange.Rows.Count
        A = .Range("A6:DS" & LastRow).Value
    End With
    ReDim B(1 To UBound(A), 1 To UBound(A, 2))
    Set Dic = CreateObject("Scripting.Dictionary")
    Dic.CompareMode = 1
    With Worksheets("Уникальные значение") ' или With Worksheets("иникальные значение") '- в файле примера
        .UsedRange.Offset(1, 0).ClearContents
        For j = 1 To UBound(A, 2)
            k = 0
            For i = 1 To UBound(A)
                S = Trim(A(i, j))
                If S <> "" Then
                    If Not Dic.Exists(S) Then
                        Dic(S) = 0&
                        k = k + 1
                        B(k, j) = S
                    End If
                End If
            Next i
        Next j
        .Range("A2").Resize(UBound(B), UBound(B, 2)) = B
    End With
End Sub
Править строку надо в .UsedRange.Offset(1, 0).ClearContents и в .Range("A2").Resize
0
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 65
30.08.2021, 17:20  [ТС]
.UsedRange.Offset(1, 0).ClearContents поправил значение в данной строке вместо 1 поставил 6 и все теперь обновляется с 6 сроки.
Насчет алгоритма удаления не уникальных значений, второй код работает идеально. Спасибо. Помогите убрать пустоты и это решение которое поможет многим. Еще раз огромное спасибо

Добавлено через 5 минут
СПАСИБО, это штука работает. Огромное спасибо вам, вы облегчили жизнь нашей загруженной сотруднице
0
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 65
31.08.2021, 18:03  [ТС]
Добрый день, подскажите как изменить код, чтобы последний результат выпадал в ячейки А4 на лист1? хочу доделать оповещение код на отправку письма через оутлук есть, осталось значение body доделать
0
 Аватар для KoGG
5643 / 1625 / 418
Регистрация: 23.12.2010
Сообщений: 2,440
Записей в блоге: 1
01.09.2021, 10:16
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
Sub Копировать_уникальные()
    Dim i&, j&, k&, LastRow&, Dic As Object, A, B, S
    With Worksheets("Плейлист")
        LastRow = .UsedRange.Rows.Count
        A = .Range("A6:DS" & LastRow).Value
    End With
    ReDim B(1 To UBound(A), 1 To UBound(A, 2))
    Set Dic = CreateObject("Scripting.Dictionary")
    Dic.CompareMode = 1
    With Worksheets("Лист1")
        .UsedRange.Offset(3, 0).ClearContents
        For j = 1 To UBound(A, 2)
            k = 0
            For i = 1 To UBound(A)
                S = Trim(A(i, j))
                If S <> "" Then
                    If Not Dic.Exists(S) Then
                        Dic(S) = 0&
                        k = k + 1
                        B(k, j) = S
                    End If
                End If
            Next i
        Next j
        .Range("A4").Resize(UBound(B), UBound(B, 2)) = B
    End With
End Sub
0
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 65
01.09.2021, 12:38  [ТС]
Простите, видно я неправильно выразился, хотелось бы выводить не все результаты, а только последний результат проверки. Т.Е. значение последнего столбца на листе "Уникальные значения" или я вас запутал?
0
 Аватар для KoGG
5643 / 1625 / 418
Регистрация: 23.12.2010
Сообщений: 2,440
Записей в блоге: 1
01.09.2021, 12:54
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
Sub Копировать_уникальные()
    Dim i&, j&, k&, LastRow&, LastCol&, Dic As Object, A, B, C, S
    With Worksheets("Плейлист")
        LastRow = .UsedRange.Rows.Count
        A = .Range("A6:DS" & LastRow).Value
    End With
    ReDim B(1 To UBound(A), 1 To UBound(A, 2))
    ReDim C(1 To UBound(A), 1 To 1)
    Set Dic = CreateObject("Scripting.Dictionary")
    Dic.CompareMode = 1
    With Worksheets("Уникальные значение")
        .UsedRange.Offset(3, 0).ClearContents
        For j = 1 To UBound(A, 2)
            k = 0
            For i = 1 To UBound(A)
                S = Trim(A(i, j))
                If S <> "" Then
                    If Not Dic.Exists(S) Then
                        Dic(S) = 0&
                        k = k + 1
                        B(k, j) = S
                        LastCol = j
                    End If
                End If
            Next i
        Next j
        .Range("A4").Resize(UBound(B), UBound(B, 2)) = B
    End With
    For i = 1 To UBound(B)
        C(i, 1) = B(i, LastCol)
    Next i
    With Worksheets("Лист1")
        .UsedRange.Offset(3, 0).ClearContents
        .Range("A4").Resize(UBound(C), UBound(C, 2)) = C
    End With
End Sub
0
0 / 0 / 0
Регистрация: 04.12.2019
Сообщений: 65
01.09.2021, 13:49  [ТС]
Заработало. Спасибо большое.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.09.2021, 13:49
Помогаю со студенческими работами здесь

Поиск уникальных элементов в массиве и запись в другой массив
есть код но он не работает, полностью копирует массив А в массив В что я не так сделал? #include &lt;stdio.h&gt; #include...

Поиск повторяющихся значений с условиями и копированием на другой лист
Всем доброго времени суток! Нашёл в поиске много аналогичных тем, но в связи с низким уровнем знаний VBA подстроить найденные решения для...

Поиск схожих значений в двух столбцах и перенос из первого на другой лист
Добрый вечер! Идея такая! Есть Два столбца, Один большой, второй меньше, нужно найти значения из столбца 2 в столбце 1, удалить их оттуда и...

Поиск на нескольких листах определенных значений и подтягивание найденных строк в другой лист
Здравствуйте. Не могу сам справиться со следующей задачей, поэтому прошу помощи. Есть файл Excel с несколькими листами. НА первый...

Копирование данных в один лист с удаление дубликатов и переносом их значений
Уважаемые знатоки VBA есть таблица учета выездов Мобильных ДГА и раз в месяц необходимо собрать данные в один лист Я попробовал написать...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru