Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RusFAQ.ru: Программирование на Basic / VBA


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный платный хостинг на базе Windows 2008

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

Тимошенко Дмитрий
Статус: Студент
Рейтинг: 266
∙ повысить рейтинг >>
Botsman
Статус: Специалист
Рейтинг: 217
∙ повысить рейтинг >>
Чичерин Вадим Викторович
Статус: 10-й класс
Рейтинг: 65
∙ повысить рейтинг >>

∙ / КОМПЬЮТЕРЫ И ПО / Языки программирования / Basic/VBA

Выпуск № 905 от 21.06.2009, 10:05
Администратор рассылки: Калашников О.А., Руководитель
В рассылке: подписчиков - 360, экспертов - 87
В номере: вопросов - 1, ответов - 2

Нам очень важно Ваше мнение об этом выпуске рассылки. Вы можете оценить этот выпуск по пятибалльной шкале, пройдя по ссылке:
оценить выпуск >>

Вопрос № 169462: Народ, помогите, пожалуйста! Есть книга Excel (некоторая база клиентов), она просто огромнейшая! Надо поставить поле для поиска (textbox), где будут вводить данные и они сразу же будут отфильтровываться и найдется нужная срока с данными в этом же ...



Вопрос № 169462:

Народ, помогите, пожалуйста!
Есть книга Excel (некоторая база клиентов), она просто огромнейшая! Надо поставить поле для поиска (textbox), где будут вводить данные и они сразу же будут отфильтровываться и найдется нужная срока с данными в этом же листе книги. Понимаю, что будет при помощи макросов, но у меня что - то не получается! Буду благодарна за помощь!

Отправлен: 16.06.2009, 10:05
Вопрос задал: Lesine, Посетитель
Всего ответов: 2
Страница вопроса >>


Отвечает Botsman, Специалист :
Здравствуйте, Lesine.
Помогаю.
Для решения вашей задачи нужно сделать следующее.
1) Вставить на лист с вашей базой данных элемент управления TextBox (если нужно - могу подробно объяснить, как это сделать)
2) По умолчанию созданный элемент находится в режиме "Конструктор". Дважды щелкаем по нему левой кнопкой мыши.
3) В появившемся окне вставляем код (заголовок [Private Sub TextBox1_Change()] и конец процедуры [End Sub] будут прописаны автоматически)
Код:

If TextBox1.Text <> "" Then
ActiveSheet.Range("$A:$H").AutoFilter Field:=1, _
Criteria1:=TextBox1.Text & "*"
Else: ActiveSheet.Range("$A:$H").AutoFilter Field:=1
End If


Примечание:
Поско льку полей 8, т.е. столбцы с A по H, то Range("$A:$H").
Фильтруем по первому полю, отсюда AutoFilter Field:=1
Данные для фильтрации должны быть текстом.
Если что - дайте знать. Разберемся

Рад был помочь.
-----
Хочешь победить Excel? Спроси меня как! ;)

Ответ отправил: Botsman, Специалист
Ответ отправлен: 17.06.2009, 11:09

Оценка ответа: 5

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 251077 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Отвечает HookEst, Специалист :
    Здравствуйте, Lesine.
    Поучаствую немного...
    в приложении три варианта реализации:
    SetFilter1 - Botsman давал такой вариант, вариант простого перебора всех строк, и скрытие ненужных
    SetFilter2 - Botsman давал такой вариант, вариант с AutoFilter
    SetFilter3 - для поиска значений используется Find, не нужные скрываются

    использование для все вариантов одинаковое, в обработчике TextBox_Change например для SetFilter3:
    Private Sub TextBox1_Change()
    SetFilter3 TextBox1
    End Sub

    на Excel 2000 так же нет возможности проверить...
    время выполнения отбора по первой букве из 50 000 строк составило:
    SetFilter1 ~8сек
    SetFilter2 ~0.04сек
    SetFilter3 ~1.2сек

    вариант, который сразу предложил Botsman(т.е. с использованием автофильтра) - вне конкуренции
    Успехов

    Приложение:

    Ответ отправил: HookEst, Специалист
    Ответ отправлен: 18.06.2009, 07:09

    Оценка ответа: 4

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 251124 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!



    Нам очень важно Ваше мнение об этом выпуске рассылки. Вы можете оценить этот выпуск по пятибалльной шкале, пройдя по ссылке:
    оценить выпуск >>

    подать вопрос экспертам этой рассылки >>

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2009, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2009.6.2 от 15.06.2009

    В избранное