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

Как искать и перемещать данные на новый (уже существующий) лист

24.10.2012, 12:27. Показов 2384. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
добрый день ,
подскажите пожалуйста цикл с переносом(вырезанием ctrl+x ), по заданным параметрам .
есть таблица с данными , нужно перебором искать нужные данные и перемещать их на новый лист (уже существующий лист)
допустим данные
первый столбец второй столбец третий и т.д.
1
2
3
4
5
5
3
5
вот нужно искать данные со значением 5 и переносить строки на другой лист .

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

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

Как создать новый лист и импортировать данные с другого листа на новый лист
как создать новый лист и импортировать данные с другого листа на новый лист. Private Sub CommandButton1_Click() ' Создание...

Новый лист с таким же названием но в конце порядковый номер если лист уже существует
Здравствуйте. Нужна маленькая помощь. Делаю копию листа , название беру из ячейки этого же листа. Но бывают такие случаи когда...

5
5472 / 1150 / 50
Регистрация: 15.09.2012
Сообщений: 3,576
24.10.2012, 14:14
Код работает с двумя первыми листами. Поиск ведётся на первом листе в столбце A, нужные строки переносятся на второй лист в первую пустую строку.
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
Sub Макрос1()
    
    'Здесь указываем, что нужно искать.
    Const lSearchText As Double = 5
    
    Dim shSheet_1 As Excel.Worksheet
    Dim shSheet_2 As Excel.Worksheet
    
    Dim lLastRowSheet_1 As Long
    Dim lLastRowSheet_2 As Long
    Dim i As Long
    
    'Для удобства написания кода будем обращаться к нужным листам
    'по именам shSheet_1 и shSheet_2.
    Set shSheet_1 = Worksheets(1)
    Set shSheet_2 = Worksheets(2)
    
    
    'Определение последних заполенных строк на двух листах.
    
    '1. Для первого листа это нужно, чтобы знать с какой ячейки начать двигаться вверх.
        'Если двигаться с самой последней ячейки в столбце, то будет долго.
    
    'Действие аналогичное тому, если сделать активной последнюю ячейку
    'в столбце A и нажать сочетание клавиш Ctrl + стрелка вверх.
    lLastRowSheet_1 = shSheet_1.Cells(shSheet_1.Rows.Count, "A").End(xlUp).Row
    
    '2. Для второго листа последняя строка с данными определяется, чтобы знать,
        'куда вставлять данные.
    lLastRowSheet_2 = shSheet_2.Cells(shSheet_2.Rows.Count, "A").End(xlUp).Row + 1
    
    
    'Отключение обновление монитора, чтобы код быстрее работал.
    Application.ScreenUpdating = False
    
    'Когда нужно удалить строку на листе, то чтобы было проще,
    'нужно идти снизу листа вверх.
    For i = lLastRowSheet_1 To 1 Step -1
        'Если в ячейке содержится искомый текст.
        If shSheet_1.Cells(i, "A").Value = lSearchText Then
        
            'Переносим строку на второй лист.
            'Я так понял, что нельзя вырезать строку с одновременным её удалением.
            'Поэтому не знаю, зачем использовать в этом случае метод Cut.
            'Буду использовать метод Copy.
            shSheet_1.Rows(i).Copy Destination:=shSheet_2.Rows(lLastRowSheet_2)
            
            'Удаление строки.
            shSheet_1.Rows(i).Delete Shift:=xlShiftUp
            
            'Задаём новый номер строки на втором листе, куда вставлять данные.
            lLastRowSheet_2 = lLastRowSheet_2 + 1
            
        End If
    Next i
 
    'Сообщение, что работа кода завершена.
    MsgBox "Работа кода завершена.", vbInformation
    
    'Включение обновления монитора.
    Application.ScreenUpdating = True
    
End Sub
0
0 / 0 / 0
Регистрация: 24.10.2012
Сообщений: 3
24.10.2012, 14:35  [ТС]
на обработку 2550 строк ушло 3.5 минуты работы макроса. это очень долго , может есть другие способы ускорить процесс ?
а вообще, за макрос спасибо!
0
5472 / 1150 / 50
Регистрация: 15.09.2012
Сообщений: 3,576
24.10.2012, 14:41
chupakabr, 46 строку в коде из сообщения #6 замените на эту:
Visual Basic
1
2
'Переносим данные из текущей строки на второй лист.
shSheet_2.Rows(lLastRowSheet_2).Value = shSheet_1.Rows(i).Value
В этом случае форматирование не переносится (размер шрифта, цвет шрифта и т.д.).
1
0 / 0 / 0
Регистрация: 24.10.2012
Сообщений: 3
24.10.2012, 14:49  [ТС]
выполнение заняло около 5 секунд, так устраивает , спасибо огромное

Добавлено через 2 минуты
а еще вопросик, можно сюда добавить несколько параметров поиска ? допустим что бы искать 5 , 3 и 2 ?
0
5472 / 1150 / 50
Регистрация: 15.09.2012
Сообщений: 3,576
24.10.2012, 18:45
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
Sub Макрос1()
    
    Dim shSheet_1 As Excel.Worksheet
    Dim shSheet_2 As Excel.Worksheet
    Dim dSearchText(1 To 3) As Double
    Dim dCellText As Double
    Dim lLastRowSheet_1 As Long
    Dim lLastRowSheet_2 As Long
    Dim i As Long, j As Long
    
    'Указываем числа, которые надо найти.
    dSearchText(1) = 2
    dSearchText(2) = 3
    dSearchText(3) = 5
    
    'Для удобства написания кода будем обращаться к нужным листам
    'по именам shSheet_1 и shSheet_2.
    Set shSheet_1 = Worksheets(1)
    Set shSheet_2 = Worksheets(2)
    
    
    'Определение последних заполенных строк на двух листах.
    
    '1. Для первого листа это нужно, чтобы знать с какой ячейки начать двигаться вверх.
        'Если двигаться с самой последней ячейки в столбце, то будет долго.
    
    'Действие аналогичное тому, если сделать активной последнюю ячейку
    'в столбце A и нажать сочетание клавиш Ctrl + стрелка вверх.
    lLastRowSheet_1 = shSheet_1.Cells(shSheet_1.Rows.Count, "A").End(xlUp).Row
    
    '2. Для второго листа последняя строка с данными определяется, чтобы знать,
        'куда вставлять данные.
    lLastRowSheet_2 = shSheet_2.Cells(shSheet_2.Rows.Count, "A").End(xlUp).Row + 1
    
    
    'Отключение обновление монитора, чтобы код быстрее работал.
    Application.ScreenUpdating = False
    
    'Когда нужно удалить строку на листе, то чтобы было проще,
    'нужно идти снизу листа вверх.
    For i = lLastRowSheet_1 To 1 Step -1
    
        'Проверяем, что в ячейке число, а не текст, чтобы не было ошибки.
        If IsNumeric(shSheet_1.Cells(i, "A").Value) = True Then
        
            'Чтобы каждый раз не обращаться к ячейке, т.к. это долго,
            'помещаем данные из ячейки в переменную.
            dCellText = shSheet_1.Cells(i, "A").Value
        
            'Просматриваем элементы массива, в котором содержатся
            'числа, которые нужно найти.
            For j = 1 To UBound(dSearchText) Step 1
                
                'Если есть совпадение.
                If dSearchText(j) = dCellText Then
                
                    'Переносим данные из текущей строки на второй лист.
                    shSheet_2.Rows(lLastRowSheet_2).Value = shSheet_1.Rows(i).Value
                    'Удаление строки.
                    shSheet_1.Rows(i).Delete Shift:=xlShiftUp
                    
                    'Задаём новый номер строки на втором листе, куда вставлять данные.
                    lLastRowSheet_2 = lLastRowSheet_2 + 1
                    
                    'Выходим из цикла просмотра массива dSearchText.
                    Exit For
                    
                End If
                
            Next j
        
        End If
            
    Next i
 
    'Сообщение, что работа кода завершена.
    MsgBox "Работа кода завершена.", vbInformation
    
    'Включение обновления монитора.
    Application.ScreenUpdating = True
    
End Sub


chupakabr, а автофильтр вы не пробовали использовать? Можно же средствами программы Excel отфильтровать, скопировать и перенести на новый лист.

Можно, наверное и этот процесс автоматизировать с помощью VBA.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.10.2012, 18:45
Помогаю со студенческими работами здесь

Очень нужно сделать новый или отредактировать уже существующий рисунок PascalABC:GraphABC
PascalABC:GraphABC Помогите сделать рисунок в окне с разрешением 1280x720 Надо сделать домик и снеговика рядом с домиком,рисунок не...

Как создать новый лист в книге со ссылкой на предыдущий лист?
Добрый день. Есть реестр учета спецтехники. Его заполняет диспетчер каждый день. т.е. каждый день копирует форму на новый лист и потом...

Как открыть уже существующий файл .docx
Доброе время суток, я хотел бы открыть файл через кнопку Button1 при её нажатии. И что бы открылся уже существующий файл пожалуйста...

Как открыть уже существующий файл .docx
Доброе время суток, я хотел бы открыть файл через кнопку Button1 при её нажатии. И что бы открылся уже существующий файл пожалуйста...

Нужно скопировать результатные данные на новый лист
Здравствуйте,помогите создать код,который будет создавать новый лист в книге и копировать результирующие данные. На Юзерформе...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru