|
10 / 0 / 2
Регистрация: 29.01.2013
Сообщений: 85
|
||||||
Combobox с поиском на VBA29.01.2013, 10:25. Показов 24340. Ответов 10
Метки нет (Все метки)
Добрый день! Нужна ваша помощь. Недавно начал осваивать VBA по рабочей необходимости возникла задача и столкнулся с проблемой, что не знаю как ее решить.
Задача у меня такая: Есть combobox, элементами списка которого служит список слов на листе Excel. Но список более 500 слов и листать его весь очень неудобно. Поэтому возникла мысль добавить в combobox поиск: Пользователь набирает часть слова и в выпадающем списке видит все слова, которые содержат введенный им с клавиатуры набор символов. При выборе соответствующего слова данное слово записывается в соответствующую ячейку. У меня получилось что-то типа этого, но работает совсем не так как нужно:
1. При вводе части текста для поиска автоматически подставляется предлагаемый вариант в текстовое поле комбо-бокса. Мне этого не нужно. 2. Выпадающий список иногда показывается как одно значение и полоса прокрутки. Нужно чтобы выпадающий список был не более 10 значений, а если более появлялся бы скролл. 3. Поиск работает криво. Подскажите как можно сделать?
0
|
||||||
| 29.01.2013, 10:25 | |
|
Ответы с готовыми решениями:
10
Проблемы с поиском в VBA Combobox в VBA
|
|
11525 / 3812 / 683
Регистрация: 13.02.2009
Сообщений: 11,229
|
||||||
| 29.01.2013, 10:46 | ||||||
|
А если взять списки?
Один невидимый. С полным перечнем. Второй отфильтрованный по введённым в тектбокс буквам на 10 видимых строк + скрол Клик по списку2 по нужному значению и отрабатывать Добавлено через 4 минуты Да даже не в списке а в массиве! зачем считывать по 1 записи? Считать в массив и перебирать массив с поиском вхождения Добавлено через 3 минуты А если уж искать совпадения на листе, то использовать не цикл, а метод Find:
Только с 13 по 18 строки замените на заполнение своего контрола(списка, комбо) Список мне нравится больше Добавлено через 50 секунд Ну и задайте свой регион поиска в строке 6 Добавлено через 2 минуты Строки 12, 20 для дополнительной проверки вам тоже могут не понадобиться
0
|
||||||
|
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
|
||
| 29.01.2013, 14:08 | ||
|
Для выделения совпадающих слов можно использовать автофильтр или расширенный фильтр на листе. Приложите файл со своими наработками.
0
|
||
|
10 / 0 / 2
Регистрация: 29.01.2013
Сообщений: 85
|
||||||
| 13.02.2013, 00:33 [ТС] | ||||||
|
Огромное спасибо, все получилось! TextBox и ListBox мне действительно больше понравились.
Единственная проблема, которая возникла - метод find ищет только по началу строки, а у меня вводимый текст для поиска может быть и в середине строки, поэтому вернулся к перебору. Правильно ли я понял, что listbox.additem наполняет список listbox, а listbox.list расставляет по порядку? Полазил по описаниям, но так и не понял до конца. И еще вопрос - есть ли какие альтернативы перебору в данном случае?
0
|
||||||
|
11525 / 3812 / 683
Регистрация: 13.02.2009
Сообщений: 11,229
|
|||
| 13.02.2013, 00:49 | |||
Буду знать теперь Добавлено через 4 минуты В твоём случае 10 строка не нужна. У меня список заполнялся по колонкам Добавлено через 3 минуты
Фильтр будет самый быстрый. Перебор самый медленный. Можно ускорить счиав в массив и обрабатывая массив
0
|
|||
|
6997 / 2895 / 555
Регистрация: 19.10.2012
Сообщений: 8,803
|
|
| 13.02.2013, 01:30 | |
|
Помнится GIG_ant делал "Удобный поиск в выпадающем списке" - именно то что нужно, бесплатно, открытый код.
0
|
|
|
10 / 0 / 2
Регистрация: 29.01.2013
Сообщений: 85
|
|
| 13.02.2013, 09:53 [ТС] | |
|
Еще раз спасибо! Просто вчера сделал через .find и у меня поиск осуществлялся только по началу слова: если ввожу какие-то символы из середины слова - не ищет. И listbox неправильно работал - после второй буквы была всего одна строчка и скрол... Вечером посмотрю еще раз и приложу то что получилось.. Буду признателен, если покажете где не прав.
0
|
|
|
11525 / 3812 / 683
Регистрация: 13.02.2009
Сообщений: 11,229
|
||||||
| 13.02.2013, 12:43 | ||||||
0
|
||||||
|
416 / 263 / 83
Регистрация: 27.10.2012
Сообщений: 861
|
|
| 06.05.2013, 00:51 | |
|
Добрый вечер! Подскажите, как к этому
прикрутить ещё пару колонок listbox'а, чтобы при поиске оставалась вся строка а не только искомая колонка.
0
|
|
|
11525 / 3812 / 683
Регистрация: 13.02.2009
Сообщений: 11,229
|
|||||||||||
| 06.05.2013, 08:02 | |||||||||||
|
Если данные записывать в одну колонку, то можно "собрать" нужные колонки в строку:
1
|
|||||||||||
|
416 / 263 / 83
Регистрация: 27.10.2012
Сообщений: 861
|
|
| 06.05.2013, 08:35 | |
|
Большое спасибо!
0
|
|
| 06.05.2013, 08:35 | |
|
Помогаю со студенческими работами здесь
11
vba ComboBox Vba convert textbox to combobox Работа со словарем combobox vba Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|