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

Объединение строк по повторяющимся значениям

11.02.2016, 17:37. Показов 2010. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Друзья немного в ступоре, функцией ВПР И СПЕЦИТЬ не получается, мб есть на то дело макрос. У меня есть макрос на удаление задвоений но он работает не совсем, так как нужно. Хотелось бы чтобы удалялись задвоения из 1го столбца, где серийный номер, а строки(которым соответствует значение обьединялись) как показано на 2м листе, но в идеале, если бы значения 11 столбца прописывались в строчку.
Вложения
Тип файла: xlsx з.xlsx (11.9 Кб, 8 просмотров)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.02.2016, 17:37
Ответы с готовыми решениями:

Объединение (Merge) ячеек по равным значениям
Ребята, При потытке создать небольшой макрос выполняющий кучу простых задач, я столкнулся с проблемой которую не знаю как решить....

Удаление повторных строк с совпадающими значениям
Уважаемые, прошу совета по оптимизации таблицы в Excele. Создавал ее не я, но приходится работать с ней именно мне. Имеется таблица с...

Найти числа в1,в2,...вm,равные наименьшим значениям строк
Найти числа в1,в2,...вm,равные наименьшим значениям строк.

7
31 / 27 / 11
Регистрация: 15.07.2015
Сообщений: 85
12.02.2016, 08:36
hannu,
Понял только, что Вы хотите объединить повторяющиеся значения первого столбца.

Над данными не должно быть пустых строк.

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Sub RangeMergeSub()
    Dim i%, j%, lRow%
    Dim lLastRow&
    lLastRow = Cells(Rows.Count, 1).End(xlUp).Row
    lRow = 0
    For i = 1 To lLastRow
        If Range("A" & i).MergeCells = False Then
            For j = i + 1 To lLastRow
                If Range("A" & i).Value = Range("A" & j).Value Then
                    lRow = j
                End If
            Next j
            If lRow > 0 Then
                Application.DisplayAlerts = False 'отключаем предупреждения. Иначе перед каждым объединением будем получать сообщение о возможной потере данных при слиянии
                Range("A" & i & ":A" & lRow).Merge
                Application.DisplayAlerts = True
            End If
            lRow = 0
        End If
    Next i
    MsgBox "done"
End Sub
0
0 / 0 / 0
Регистрация: 08.04.2015
Сообщений: 135
12.02.2016, 14:04  [ТС]
Попробовал обработать массив, не сработало, все остается тоже самое и выскакивает диалоговое окно Done
0
31 / 27 / 11
Регистрация: 15.07.2015
Сообщений: 85
12.02.2016, 14:21
Цитата Сообщение от hannu Посмотреть сообщение
Попробовал обработать массив, не сработало, все остается тоже самое и выскакивает диалоговое окно Done
1. Проверка осуществляется по первому столбцу "А". Т.е. все ID должны содержаться в нем.
2. Выше таблицы не должно быть пустых строк. Т.е., строка:
Visual Basic
1
lLastRow = Cells(Rows.Count, 1).End(xlUp).Row
определяет последнюю, непустую ячейку. В вашей таблице, которую Вы вложили в первый пост, сверху было три пустых строки, отчего, я специально указал, что:
Цитата Сообщение от RoyDenzel Посмотреть сообщение
Над данными не должно быть пустых строк.
3. Цикл проверяет каждую непустую ячейку с ID, и если она не имеет слияния, начинает с ней работать.
0
0 / 0 / 0
Регистрация: 08.04.2015
Сообщений: 135
12.02.2016, 14:27  [ТС]
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
Sub УдалДвойнСтроки()
Set CurrentCell = ActiveCell
Do While Not IsEmpty(CurrentCell)
Set nextCell = CurrentCell.Offset(1, 0)
If nextCell.Value = CurrentCell.Value Then
'CurrentCell.Delete Shift:=xlUp 'Включать если надо удалять только ячейку
CurrentCell.EntireRow.Delete 'Включать если надо удалять всю строку
End If
Set CurrentCell = nextCell
Loop
End Sub

а можно подредактировать этот макрос, но не удалять строку или ячейку а попробовать обьединить? Просто выгрузка из 1С кривая и получается так, что бывают пустоты
0
12.02.2016, 14:31

Не по теме:

:wall:

0
0 / 0 / 0
Регистрация: 08.04.2015
Сообщений: 135
12.02.2016, 14:34  [ТС]
Вроде понял, сорь за тупняк, только вопрос он начинает проверку с ячейки А1? или таблица может находится в произвольнмо порядке,
0
31 / 27 / 11
Регистрация: 15.07.2015
Сообщений: 85
12.02.2016, 14:44
Последняя строка определяется по первому столбцу "А":
Visual Basic
1
 lLastRow = Cells(Rows.Count, 1).End(xlUp).Row
Если хотите, например по 5 "Е", то вместо этой строки нужно указать:
Visual Basic
1
 lLastRow = Cells(Rows.Count, 5).End(xlUp).Row
Нужно выбирать тот столбец, который не может быть пустым, в этом случае, без разницы, сколько строк в таблице, они отработаются все.

Эта строка:
Visual Basic
1
Range("A" & i & ":A" & lRow).Merge
Сливает ячейки в столбце "А", если они соседние столбцы равны по значению. Если нужно установить другой столбец, вместо "А" и ":А", указать любую другую букву столбца.


Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Sub RangeMergeSub()
    Dim i%, j%, lRow% 'объявляем переменные integer
    Dim lLastRow& 'объявляем переменные long
    lLastRow = Cells(Rows.Count, 1).End(xlUp).Row 'определяем последнюю непустую строку
    lRow = 0 'сбрасываем счетчик одинаковых ячеек
    For i = 1 To lLastRow 'основной цикл, проверяет все ячейки
        If Range("A" & i).MergeCells = False Then 'если ячейка не имеет слияния, значит она не обработана
            For j = i + 1 To lLastRow 'вложенный цикл ищет одинаковые значения с проверяемой ячейкой
                If Range("A" & i).Value = Range("A" & j).Value Then 'если ячейки одинаковы
                    lRow = j 'запоминаем крайний номер ячейки до которой нужно слить
                End If
            Next j
            If lRow > 0 Then 'если такие ячейки были найдены
                Application.DisplayAlerts = False 'отключаем предупреждения. Иначе перед каждым объединением будем получать сообщение о возможной потере данных при слиянии
                Range("A" & i & ":A" & lRow).Merge 'сливаем их
                Application.DisplayAlerts = True
            End If
            lRow = 0 'сбрасываем счетчик
        End If
    Next i
    MsgBox "done"
End Sub
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.02.2016, 14:44
Помогаю со студенческими работами здесь

Сортировка строк по числовым значениям, содержащимся в них
Есть массив строк: str_arr = Пытаюсь отсортировать методом sort, ожидая получить результат, как при сортировке чисел, но получаю...

Сортировка данных в столбцах по значениям строк в первом столбце
Приветствую всех пользователей данного ресурса! Гуру Excel и просто опытные пользователи, нужна ваша помощь! Целый день ломаю голову,...

Определить числа b1, ... , bm равные наименьшим значениям элементов строк
Дана действительная матрица размера m x n. Определить числа b1, ... , bm равные наименьшим значениям элементов строк.

Определить числа, равные наименьшим значениям элементов строк матрицы
1. Дана действительная матрица размера m*n. Определить числа b1, b2,… bm равные соответственно наименьшим значениям элементов строк.

Определить числа b1,...bm равные значениям средних арифметических элементов строк
пожалуйста помогите решить задачи в делфи. 1. Дана действительная матрица размера m х n. Определить числа b1,...bm равные значениям...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
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 Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
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 позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru