3 / 3 / 0
Регистрация: 12.12.2015
Сообщений: 174
|
|
1 | |
Как убрать «лишнее» из массива?05.08.2018, 17:48. Показов 1895. Ответов 7
Метки нет (Все метки)
Доброго времени суток! Уважаемые форумчане, Появилась архисложная для меня задачка. Пожалуйста помогите её порешать?
Задача: Есть диапазон ячеек (A2:J33). В нём есть «лишние строки», те где в столбцах “D” и ”E” прописано значение “X”. Нужны Действия: 1) Удалить все строки, где есть “X” в столбцах “D” и ”E”. 2) Удалить все строки, где ячейка столбца “C” не равна «МЦ» 3) Получить массив содержащий строки по условию «Столбец “A” содержит указанный номер работ.» 4) Отсортировать полученный новый массив по столбцу “I” 5) Записать отсортированный массив в указанный лист книги. Или подскажите как решаются подобные случаи?
0
|
05.08.2018, 17:48 | |
Ответы с готовыми решениями:
7
Убрать лишнее сообщение Как убрать лишнее Как убрать лишнее? Как убрать лишнее пространство |
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
|
|
05.08.2018, 18:22 | 2 |
Стандартным фильтром. Отбираете те, кто с нужным номером (т.е. удаляете всех не с нужным), затем из них удаляете все кто не МЦ, из оставшихся фильтр по двум столбцам по "X" и тоже удаляете.
Затем оставшееся сортируете. Да, забыл - первым делом копируете исходный массив данных . Ну а на VBA можно делать "тупо в лоб" - цикл по строкам, проверка всех условий - и если строка годится, то копируем куда задумано, наращивая например счётчик строк. В конце результат сортируем.
0
|
3 / 3 / 0
Регистрация: 12.12.2015
Сообщений: 174
|
|
05.08.2018, 18:28 [ТС] | 3 |
Вот и не получилось у меня цикла, чтоб отобрать в новый массив нужные строки
Стандартным фильтром, однако 4 к строк будут долго удалятся, но это как крайний вариант. И не можно мне сразу массив в указанный лист бросать. Мне ещё несколько выборок делать нужно, и в определенном порядке прописывать по местам. Потому и хочу виртуальный массив получить, а из него уже всё что требуется, т.е. по вариантам.
0
|
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
|
|
05.08.2018, 18:46 | 4 |
Ну можно и так - взять всё в массив (виртуальный, в память), далее циклом идти как угодно, анализировать строки массива и номера нужных строк запоминать в коллекцию.
Когда коллекция собрана - создать под размер массив, и циклом по коллекции переложить строки из массива в массив. Результирующий выгрузить на место, отсортировать средствами листа. Ну или как вариант - из коллекции выгрузить в массив из двух столбцов номера строк и значения для сортировки, его отсортировать, и теперь уже циклом по этому массиву сразу собирать итоговый в нужном порядке. Это всё с учётом что 4000 и чтоб было быстро. Но сортировать думаю быстрее средствами листа. Добавлено через 1 минуту Иногда делают так - чтоб не плодить массивы/коллекции, перекладывают отобранные строки в этом же массиве наверх, в конце эту собранную верхушку выгружают. Ну и затем уже можно сортировать. Тоже кстати применимо в этой задаче.
0
|
3 / 3 / 0
Регистрация: 12.12.2015
Сообщений: 174
|
|
05.08.2018, 18:55 [ТС] | 5 |
0
|
6922 / 2832 / 543
Регистрация: 19.10.2012
Сообщений: 8,645
|
||||||
05.08.2018, 19:11 | 6 | |||||
Сообщение было отмечено Sasanik как решение
Решение
Вот по второй схеме без сортировки - тут и отобрать, и переложить, и выгрузить. Осталось отсортировать, и может форматы столбцам задать (до выгрузки!)
1
|
3 / 3 / 0
Регистрация: 12.12.2015
Сообщений: 174
|
|
05.08.2018, 19:52 [ТС] | 7 |
Hugo121, Спасибо! Буду пробовать.Я тут с автофильтром побаловался, мои данные секунд пять обрабатываются. Сравню способы отчитаюсь.
0
|
3 / 3 / 0
Регистрация: 12.12.2015
Сообщений: 174
|
|
27.10.2018, 18:45 [ТС] | 8 |
Спасибо! Огромное, Hugo121, Проверил, опробовал в нескольких отчетах, всё заработало! , как хотелось.
0
|
27.10.2018, 18:45 | |
27.10.2018, 18:45 | |
Помогаю со студенческими работами здесь
8
Как убрать из папок все лишнее? Как убрать лишнее из вывода grep? Как убрать лишнее с главной страницы? Как убрать лишнее из компилированного ексешника? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |