ПОИСК, ПОИСКБ (функции ПОИСК, ПОИСКБ)
Excel для Microsoft 365 Excel для Microsoft 365 для Mac Excel для Интернета Excel 2019 Excel 2019 для Mac Excel 2016 Excel 2016 для Mac Excel 2013 Excel 2010 Excel 2007 Excel для Mac 2011 Excel Starter 2010 Еще…Меньше
В этой статье описаны синтаксис формулы и использование функций ПОИСК и ПОИСКБ в Microsoft Excel.
Описание
Функции ПОИСК И ПОИСКБ находят одну текстовую строку в другой и возвращают начальную позицию первой текстовой строки (считая от первого символа второй текстовой строки). Например, чтобы найти позицию буквы «n» в слове «printer», можно использовать следующую функцию:
=ПОИСК(«н»;»принтер»)
Эта функция возвращает 4, так как «н» является четвертым символом в слове «принтер».
Можно также находить слова в других словах. Например, функция
=ПОИСК(«base»;»database»)
возвращает 5, так как слово «base» начинается с пятого символа слова «database». Можно использовать функции ПОИСК и ПОИСКБ для определения положения символа или текстовой строки в другой текстовой строке, а затем вернуть текст с помощью функций ПСТР и ПСТРБ или заменить его с помощью функций ЗАМЕНИТЬ и ЗАМЕНИТЬБ. Эти функции показаны в примере 1 данной статьи.
Важно:
-
Эти функции могут быть доступны не на всех языках.
-
Функция ПОИСКБ отсчитывает по два байта на каждый символ, только если языком по умолчанию является язык с поддержкой БДЦС. В противном случае функция ПОИСКБ работает так же, как функция ПОИСК, и отсчитывает по одному байту на каждый символ.
К языкам, поддерживающим БДЦС, относятся японский, китайский (упрощенное письмо), китайский (традиционное письмо) и корейский.
Синтаксис
ПОИСК(искомый_текст;просматриваемый_текст;[начальная_позиция])
ПОИСКБ(искомый_текст;просматриваемый_текст;[начальная_позиция])
Аргументы функций ПОИСК и ПОИСКБ описаны ниже.
-
Искомый_текст Обязательный. Текст, который требуется найти.
-
Просматриваемый_текст Обязательный. Текст, в котором нужно найти значение аргумента искомый_текст.
-
Начальная_позиция Необязательный. Номер знака в аргументе просматриваемый_текст, с которого следует начать поиск.
Замечание
-
Функции ПОИСК и ПОИСКБ не учитывают регистр. Если требуется учитывать регистр, используйте функции НАЙТИ и НАЙТИБ.
-
В аргументе искомый_текст можно использовать подстановочные знаки: вопросительный знак (?) и звездочку (*). Вопросительный знак соответствует любому знаку, звездочка — любой последовательности знаков. Если требуется найти вопросительный знак или звездочку, введите перед ним тильду (~).
-
Если значение find_text не найдено, #VALUE! возвращается значение ошибки.
-
Если аргумент начальная_позиция опущен, то он полагается равным 1.
-
Если start_num больше нуля или больше, чем длина аргумента within_text, #VALUE! возвращается значение ошибки.
-
Аргумент начальная_позиция можно использовать, чтобы пропустить определенное количество знаков. Допустим, что функцию ПОИСК нужно использовать для работы с текстовой строкой «МДС0093.МужскаяОдежда». Чтобы найти первое вхождение «М» в описательной части текстовой строки, задайте для аргумента начальная_позиция значение 8, чтобы поиск не выполнялся в той части текста, которая является серийным номером (в данном случае — «МДС0093»). Функция ПОИСК начинает поиск с восьмого символа, находит знак, указанный в аргументе искомый_текст, в следующей позиции, и возвращает число 9. Функция ПОИСК всегда возвращает номер знака, считая от начала просматриваемого текста, включая символы, которые пропускаются, если значение аргумента начальная_позиция больше 1.
Примеры
Скопируйте образец данных из следующей таблицы и вставьте их в ячейку A1 нового листа Excel. Чтобы отобразить результаты формул, выделите их и нажмите клавишу F2, а затем — клавишу ВВОД. При необходимости измените ширину столбцов, чтобы видеть все данные.
Данные |
||
Выписки |
||
Доход: маржа |
||
маржа |
||
Здесь «босс». |
||
Формула |
Описание |
Результат |
=ПОИСК(«и»;A2;6) |
Позиция первого знака «и» в строке ячейки A2, начиная с шестого знака. |
7 |
=ПОИСК(A4;A3) |
Начальная позиция строки «маржа» (искомая строка в ячейке A4) в строке «Доход: маржа» (ячейка, в которой выполняется поиск — A3). |
8 |
=ЗАМЕНИТЬ(A3;ПОИСК(A4;A3);6;»объем») |
Заменяет слово «маржа» словом «объем», определяя позицию слова «маржа» в ячейке A3 и заменяя этот знак и последующие пять знаков текстовой строкой «объем.» |
Доход: объем |
=ПСТР(A3;ПОИСК(» «;A3)+1,4) |
Возвращает первые четыре знака, которые следуют за первым пробелом в строке «Доход: маржа» (ячейка A3). |
марж |
=ПОИСК(«»»»;A5) |
Позиция первой двойной кавычки («) в ячейке A5. |
5 |
=ПСТР(A5;ПОИСК(«»»»;A5)+1;ПОИСК(«»»»;A5;ПОИСК(«»»»;A5)+1)-ПОИСК(«»»»;A5)-1) |
Возвращает из ячейки A5 только текст, заключенный в двойные кавычки. |
босс |
Нужна дополнительная помощь?
Содержание
- Поисковая функция в Excel
- Способ 1: простой поиск
- Способ 2: поиск по указанному интервалу ячеек
- Способ 3: Расширенный поиск
- Вопросы и ответы
В документах Microsoft Excel, которые состоят из большого количества полей, часто требуется найти определенные данные, наименование строки, и т.д. Очень неудобно, когда приходится просматривать огромное количество строк, чтобы найти нужное слово или выражение. Сэкономить время и нервы поможет встроенный поиск Microsoft Excel. Давайте разберемся, как он работает, и как им пользоваться.
Поисковая функция в Excel
Поисковая функция в программе Microsoft Excel предлагает возможность найти нужные текстовые или числовые значения через окно «Найти и заменить». Кроме того, в приложении имеется возможность расширенного поиска данных.
Способ 1: простой поиск
Простой поиск данных в программе Excel позволяет найти все ячейки, в которых содержится введенный в поисковое окно набор символов (буквы, цифры, слова, и т.д.) без учета регистра.
- Находясь во вкладке «Главная», кликаем по кнопке «Найти и выделить», которая расположена на ленте в блоке инструментов «Редактирование». В появившемся меню выбираем пункт «Найти…». Вместо этих действий можно просто набрать на клавиатуре сочетание клавиш Ctrl+F.
- После того, как вы перешли по соответствующим пунктам на ленте, или нажали комбинацию «горячих клавиш», откроется окно «Найти и заменить» во вкладке «Найти». Она нам и нужна. В поле «Найти» вводим слово, символы, или выражения, по которым собираемся производить поиск. Жмем на кнопку «Найти далее», или на кнопку «Найти всё».
- При нажатии на кнопку «Найти далее» мы перемещаемся к первой же ячейке, где содержатся введенные группы символов. Сама ячейка становится активной.
Поиск и выдача результатов производится построчно. Сначала обрабатываются все ячейки первой строки. Если данные отвечающие условию найдены не были, программа начинает искать во второй строке, и так далее, пока не отыщет удовлетворительный результат.
Поисковые символы не обязательно должны быть самостоятельными элементами. Так, если в качестве запроса будет задано выражение «прав», то в выдаче будут представлены все ячейки, которые содержат данный последовательный набор символов даже внутри слова. Например, релевантным запросу в этом случае будет считаться слово «Направо». Если вы зададите в поисковике цифру «1», то в ответ попадут ячейки, которые содержат, например, число «516».
Для того, чтобы перейти к следующему результату, опять нажмите кнопку «Найти далее».
Так можно продолжать до тех, пор, пока отображение результатов не начнется по новому кругу.
- В случае, если при запуске поисковой процедуры вы нажмете на кнопку «Найти все», все результаты выдачи будут представлены в виде списка в нижней части поискового окна. В этом списке находятся информация о содержимом ячеек с данными, удовлетворяющими запросу поиска, указан их адрес расположения, а также лист и книга, к которым они относятся. Для того, чтобы перейти к любому из результатов выдачи, достаточно просто кликнуть по нему левой кнопкой мыши. После этого курсор перейдет на ту ячейку Excel, по записи которой пользователь сделал щелчок.
Способ 2: поиск по указанному интервалу ячеек
Если у вас довольно масштабная таблица, то в таком случае не всегда удобно производить поиск по всему листу, ведь в поисковой выдаче может оказаться огромное количество результатов, которые в конкретном случае не нужны. Существует способ ограничить поисковое пространство только определенным диапазоном ячеек.
- Выделяем область ячеек, в которой хотим произвести поиск.
- Набираем на клавиатуре комбинацию клавиш Ctrl+F, после чего запуститься знакомое нам уже окно «Найти и заменить». Дальнейшие действия точно такие же, что и при предыдущем способе. Единственное отличие будет состоять в том, что поиск выполняется только в указанном интервале ячеек.
Способ 3: Расширенный поиск
Как уже говорилось выше, при обычном поиске в результаты выдачи попадают абсолютно все ячейки, содержащие последовательный набор поисковых символов в любом виде не зависимо от регистра.
К тому же, в выдачу может попасть не только содержимое конкретной ячейки, но и адрес элемента, на который она ссылается. Например, в ячейке E2 содержится формула, которая представляет собой сумму ячеек A4 и C3. Эта сумма равна 10, и именно это число отображается в ячейке E2. Но, если мы зададим в поиске цифру «4», то среди результатов выдачи будет все та же ячейка E2. Как такое могло получиться? Просто в ячейке E2 в качестве формулы содержится адрес на ячейку A4, который как раз включает в себя искомую цифру 4.
Но, как отсечь такие, и другие заведомо неприемлемые результаты выдачи поиска? Именно для этих целей существует расширенный поиск Excel.
- После открытия окна «Найти и заменить» любым вышеописанным способом, жмем на кнопку «Параметры».
- В окне появляется целый ряд дополнительных инструментов для управления поиском. По умолчанию все эти инструменты находятся в состоянии, как при обычном поиске, но при необходимости можно выполнить корректировку.
По умолчанию, функции «Учитывать регистр» и «Ячейки целиком» отключены, но, если мы поставим галочки около соответствующих пунктов, то в таком случае, при формировании результата будет учитываться введенный регистр, и точное совпадение. Если вы введете слово с маленькой буквы, то в поисковую выдачу, ячейки содержащие написание этого слова с большой буквы, как это было бы по умолчанию, уже не попадут. Кроме того, если включена функция «Ячейки целиком», то в выдачу будут добавляться только элементы, содержащие точное наименование. Например, если вы зададите поисковый запрос «Николаев», то ячейки, содержащие текст «Николаев А. Д.», в выдачу уже добавлены не будут.
По умолчанию, поиск производится только на активном листе Excel. Но, если параметр «Искать» вы переведете в позицию «В книге», то поиск будет производиться по всем листам открытого файла.
В параметре «Просматривать» можно изменить направление поиска. По умолчанию, как уже говорилось выше, поиск ведется по порядку построчно. Переставив переключатель в позицию «По столбцам», можно задать порядок формирования результатов выдачи, начиная с первого столбца.
В графе «Область поиска» определяется, среди каких конкретно элементов производится поиск. По умолчанию, это формулы, то есть те данные, которые при клике по ячейке отображаются в строке формул. Это может быть слово, число или ссылка на ячейку. При этом, программа, выполняя поиск, видит только ссылку, а не результат. Об этом эффекте велась речь выше. Для того, чтобы производить поиск именно по результатам, по тем данным, которые отображаются в ячейке, а не в строке формул, нужно переставить переключатель из позиции «Формулы» в позицию «Значения». Кроме того, существует возможность поиска по примечаниям. В этом случае, переключатель переставляем в позицию «Примечания».
Ещё более точно поиск можно задать, нажав на кнопку «Формат».
При этом открывается окно формата ячеек. Тут можно установить формат ячеек, которые будут участвовать в поиске. Можно устанавливать ограничения по числовому формату, по выравниванию, шрифту, границе, заливке и защите, по одному из этих параметров, или комбинируя их вместе.
Если вы хотите использовать формат какой-то конкретной ячейки, то в нижней части окна нажмите на кнопку «Использовать формат этой ячейки…».
После этого, появляется инструмент в виде пипетки. С помощью него можно выделить ту ячейку, формат которой вы собираетесь использовать.
После того, как формат поиска настроен, жмем на кнопку «OK».
Бывают случаи, когда нужно произвести поиск не по конкретному словосочетанию, а найти ячейки, в которых находятся поисковые слова в любом порядке, даже, если их разделяют другие слова и символы. Тогда данные слова нужно выделить с обеих сторон знаком «*». Теперь в поисковой выдаче будут отображены все ячейки, в которых находятся данные слова в любом порядке.
- Как только настройки поиска установлены, следует нажать на кнопку «Найти всё» или «Найти далее», чтобы перейти к поисковой выдаче.
Как видим, программа Excel представляет собой довольно простой, но вместе с тем очень функциональный набор инструментов поиска. Для того, чтобы произвести простейший писк, достаточно вызвать поисковое окно, ввести в него запрос, и нажать на кнопку. Но, в то же время, существует возможность настройки индивидуального поиска с большим количеством различных параметров и дополнительных настроек.
Программа Excel ориентирована на ускоренные расчеты. Зачастую документы здесь состоят из большого ко…
Программа Excel ориентирована на ускоренные расчеты. Зачастую документы здесь состоят из большого количества листов, на которых представлены длинные таблицы с числами, формулами или текстом. Для удобного нахождения нужных ячеек существует специальный автоматизированный поиск. Ознакомившись с особенностями его использования, можно сократить время работы в документах. О том, как искать в Экселе слова, фразы или ячейки, подробно написано ниже.
Поиск слов
Документы часто имеют много страниц, тогда встает вопрос о том, как в Еxcel найти слово. Сделать это иногда становится проблематично. Для упрощения этой задачи существует специальная функция поиска. Чтобы ею воспользоваться, необходимо выполнить следующий алгоритм действий:
- запустить программу Excel;
- проверить активность таблицы, щелкнув по любой из ячеек;
- нажать комбинацию клавиш «Ctrl + F»;
- в строке «Найти» появившегося окна ввести искомое слово;
- нажать «Найти».
В результате программа активирует поисковую функцию, а найденные слова в таблице или книге будут подсвечены.
Существует также способ нестрогого поиска, который подходит для ситуаций, когда искомое слово помнится частично. Он предусматривает использование символов-заменителей (джокерные символы). В Excel их всего два:
- «?» – подразумевает любой отдельно взятый символ;
- «*» – обозначает любое количество символов.
Примечательно, при поиске вопросительного знака или знака умножения дополнительно впереди ставится тильда («~»). При поиске тильды, соответственно – две тильды.
Алгоритм неточного поиска слова:
- запустить программу;
- активировать страницу щелчком мыши;
- зажать комбинацию клавиш «Ctrl + F»;
- в строке «Найти» появившегося окна ввести искомое слово, используя вместо букв, вызывающих сомнения, джокерные символы;
- проверить параметр «Ячейка целиком» (он не должен быть отмеченным);
- нажать «Найти все».
Все слова, подходящие под параметры поиска, подсветятся, поэтому их легко будет увидеть и проанализировать.
Поиск нескольких слов
Не зная, как найти слово в таблице в Еxcel, следует также воспользоваться функцией раздела «Редактирование» – «Найти и выделить». Далее нужно отталкиваться от искомой фразы:
- если фраза точная, введите ее и нажмите клавишу «Найти все»;
- если фраза разбита другими ключами, нужно при написании ее в строке поиска дополнительно проставить между всеми словами «*».
В первом случае поиск выдаст все результаты с точной поисковой фразой, игнорируя другие склонения или разбавленные ее варианты. Во втором случае отыщутся все значения с введенными надписями, даже если между ними присутствуют другие символы.
Поиск ячеек
Ячейки могут содержать в себе формулы или значения, быть объеденными или скрытыми. Эти характеристики изменяют ход поиска интересующих нас ячеек.
Для поиска ячеек с формулами выполняются следующие действия.
- В открытом документе выделить ячейку или диапазон ячеек (в первом случае поиск идет по всему листу, во втором – в выделенных ячейках).
- Во вкладке «Главная» выбрать функцию «Найти и выделить».
- Обозначить команду «Перейти».
- Выделить клавишу «Выделить».
- Выбрать «Формулы».
- Обратить внимание на список пунктов под «Формулами» (возможно, понадобится снятие флажков с некоторых параметров).
- Нажать клавишу «Ок».
Для поиска объединенных ячеек потребуется выполнение следующих манипуляций.
- Перейти во вкладку «Главная».
- Выбрать функцию «Найти и выделить».
- Нажать на команду «Найти».
- Перейти в «Параметры» и выбрать «Формат».
- Здесь выделить функцию «Выравнивание», поставить отметку «Объединить ячейки».
- Нажать на «Ок».
- Нажать на кнопку «Найти все» и проанализировать список ячеек, которые объединены на соответствующем листе.
При нажимании кнопкой мыши на элемент в списке происходит выделение объединенной ячейки на листе. Дополнительно доступна функция «Отменить объединение ячеек».
Выполнение представленных выше действий приводит к нахождению всех объединенных ячеек на листе и при необходимости отмене данного свойства. Для поиска скрытых ячеек проводятся следующие действия.
- Выбрать лист, требующий анализа на присутствие скрытых ячеек и их нахождения.
- Нажать клавиши «F5_гт_
Special». - Нажать сочетание клавиш «CTRL + G_гт_ Special».
Можно воспользоваться еще одним способом для поиска скрытых ячеек:
- Открыть функцию «Редактирование» во вкладке «Главная».
- Нажать на «Найти».
- Выбрать команду «Перейти к разделу». Выделить «Специальные».
- Попав в группу «Выбор», поставить галочку на «Только видимые ячейки».
- Нажать кнопку «Ок».
В результате проделанных действий видимые ячейку выделятся, при этом границы столбцов и строк, которые граничат со скрытыми ячейками или столбцами, предстанут с белыми границами.
Если интересующая ячейка обозначена условным форматом, ее несложно найти и применить для копирования, удаления или редактирования непосредственно условного формата. Если речь идет о ячейке с определенным условным форматом, тогда на помощь придет функция «Выделить группу ячеек».
Чтобы найти ячейки, для которых применено условное форматирование:
- нажать на ячейку, не предусматривающую условное форматирование;
- выбрать функцию «Редактирование» во вкладке «Главная»;
- нажать на кнопку «Найти и выделить»;
- выделить категорию «Условное форматирование».
Чтобы найти ячейки, для которых применено одинаковое условное форматирование:
- выбрать ячейку, предусматривающую условное форматирование, требующую поиска;
- выбрать группу «Редактирование» во вкладке «Главная»;
- нажать на кнопку «Найти и выделить»;
- выбрать категорию «Выделить группу ячеек»;
- установить свойство «Условные форматы»;
- напоследок нужно зайти в группу «Проверка данных» и установить аналогичный пункт.
Поиск через фильтр
Чтобы узнать, как в Еxcel найти слово при использовании фильтра, потребуется изучить следующий алгоритм действий:
- выделить заполненную ячейку;
- во вкладке «Главная» выбрать функцию «Сортировка»;
- нажать на кнопку «Фильтр»;
- открыть выпадающее меню;
- ввести искомый запрос;
- нажать кнопку «Ок».
В результате в столбце выделятся только ячейки с искомым значением. Для сбрасывания результатов поиска в выпадающем списке необходимо нажать на «Выделить все». Для отключения фильтра потребуется еще раз нажать на его значок в функции «Сортировка». Примечательно, данный способ не даст результатов, если неизвестен ряд с искомым значением.
Проверка ячейки на наличие в ней текста (без учета регистра)
Смотрите также arr = Range([a1],: А иначе? Если функция сравнивается сЧтобы легко понять, как листе «ДАННЫЕ» в внутри слова, напримерС запасом, но 10, т.к. слово ПРАВСИМВ. Функция ДЛСТРВторой аргумент функции –Во-первых, спасибо заВитушка есть решение проще. Дана таблица. В грамматические ошибки. ДляФорматПримечание: [a100]).Value For i НЕ нашли, то значением строки «C». удалось экспонировать цветом
каждой ячейке последней «собранный» короче Код =ПРОСМОТР(2;1/(ПОИСК(Лист2!B$2:B$99;B3)-1);Лист2!B$2:B$99) «Захар» начинается с «считает» общую длину формат. Где брать формулу: Код =ИНДЕКС(Лист1!$C$1:$C$99;ПОИСКПОЗ(ЛОЖЬ;ЕНД(ПОИСКПОЗ(«*»&Лист1!$A$1:$A$99&»*»;A25;));)): Доброго всем вечера!Анастасия_П первом столбце наименования, нас важно, чтобыи внесите нужныеМы стараемся как
= 1 To что занести вВо всех выше описанных определенные значения с строчкой.
Поиск ячеек, содержащих текст
ManyashaЕвгений8510 десятого символа в
-
текста. Затем отнимается строку формата? Щелкаем У меня
У меня похожая: я в вопросе содержащие одни и
-
эта статья была изменения во всплывающем можно оперативнее обеспечивать 100 If UCase(arr(i, В1! примерах очень легко помощью условного форматированияВОТ файл:Потстановка соответсвующей:
-
: Спасибо AlexM, Вы строке. Где это количество знаков до правой кнопкой мыши возникла проблема, антологичная задача, помогите, плиз, сами наименования упростила, те же слова, вам полезна. Просим
окне вас актуальными справочными 1)) Like UCase(«яблоко»)
-
Валерий аникин применять текстовые функции разберем этапы действий статьи.xlsxsweta212 правы, диапазон на может пригодиться? первого пробела (найденное
-
по ячейке со выше описанным: по написать формулу для а в идеале но записаны по вас уделить паруНайти формат материалами на вашем
Then iCnt2 =: http://scriptcoding.ru/2013/11/10/vba-strokovyje-funkciji/ в условном форматировании в двух словах.Помогите, пожалуйста!!!, Оформите формулу тегами листе2 действительно неФункция ПОИСК определяет положение ПОИСКом). значением. Нажимаем «Формат
-
фрагменту текста найти следующих условий. Если они как в разному. Например: «коньяк секунд и сообщить,
. языке. Эта страница iCnt2 + 1Шведов сергей так как длина Сначала мы извлекаемVlad999 (кнопка 9 позиций, а
знака в текстовойВторая строка содержит имя, ячеек». В открывшемся
Проверка ячейки на наличие в ней любого текста
слово в массиве в тексте столбца файле… Янтарный замок», «Янтарный
Проверка соответствия содержимого ячейки определенному тексту
помогла ли онаКнопка переведена автоматически, поэтому Next i ‘итог: в В1 формулу. строк в исходных
Проверка соответствия части ячейки определенному тексту
часть текста, а: Код =ПРОСМОТР(9^9;ПОИСК(Статья!$A$1:$A$24;Данные!D2);Статья!$A$1:$A$24)fx гораздо больше, а строке. А функция отчество и фамилию. окне выбираем «все и заменить название,
А «Назначение платежа»Казанский замок коньяк 0,5″, вам, с помощью
support.office.com
Проверка ячейки на наличие в ней текста (с учетом регистра)
Параметры ее текст может MsgBox «На листе к регистру не данных одинаковая. Но потом сравниваем егоНаташа Демчук) Ваш вариант решает ПСТР возвращает текстовые Для имени используем форматы». Копируем нужный на то, которое листа «отчет» содержится: Код =ЕСЛИ(ЕОШ(ПОИСК(«казачок»;A2));ЕСЛИ(ЕОШ(ПОИСК(«янтарный замок»;A2));»?»;»10 «коньяк Янтарный замок кнопок внизу страницы.служит для задания содержать неточности и » & iCnt1 чувствительна что, если у
с требуемым значением.: Видела похожее здесь,InExSu задачу когда список значения (см. пример такую же формулу: в строке «Тип». требуется по справочнику. слово из столбца янтарный замок»);»11 казачок») трехлетний 0,5″, «водка
Сравнение ячейки с другой ячейкой
Для удобства также более подробных условий грамматические ошибки. Для
& » ябл.»=ЕСЛИ (ЕСЛИОШИБКА (ПОИСК нас в исходных Но как из
Сравнение значения со значениями из списка
но не получилось: Привет! на листе2 пополняется
выше). Либо можноФормула для извлечения фамилии Вставляем скопированное значение Мне нужно сделать А листа «списки», В примере работает. казачок», «казачок водка приводим ссылку на поиска. Например, можно найти нас важно, чтобы & vbLf & («Анонс»;A1);ЕСЛИОШИБКА (ПОИСК («икона»;A1);ЕСЛИОШИБКА данных разного типа ячейки извлечь часть применить формулы(((вариант решения ждёт автоматически. Спасибо ещё заменить найденный текст несколько иная: Это в формулу.
Проверка соответствия части ячейки определенному тексту
эту формулу, через то в столбцеВот так логически
0,7л». Во второй оригинал (на английском все ячейки, содержащие
эта статья была «В массиве « (ПОИСК («суббота»;A1);-1)))>0;A1;»»)
индикаторы с разной
-
текста в Excel?Поиск фрагментов текста
-
выполнения требования модератора раз! посредством функции ЗАМЕНИТЬ.
support.office.com
Поиск фрагментов текста в ячейке
пять знаков справа.Приведем еще пример, где
ЕСЛИОШИБКА. Тоже есть В «Филиал» на проще «достраивать» формулу столбец нужно ввести языке) . данных определенного типа, вам полезна. Просим & iCnt2 &Успехов! длинной символов, а Обратим внимание на в ячейкеsweta212sweta212Скачать пример функции для Вложенные функции ПОИСК может быть полезна пример. листе «отчет» должно для других наименований: текст «10 янтарныйПредположим, что требуется найти такого как формулы. вас уделить пару » ябл.» EndАлексей матевосов (alexm) нам все еще функцию =ПСТР() вСПАСИБО!!!!РАБОТАЕТ!!! БОЛЬШОЕ СПАСИБО!!!: InExSu, спасибо, что: Есть товарные категории работы с текстом
ищут второй и данная функция. Добавим
НО! Копирую формулу встать соответствие из Код =ЕСЛИ(ЕЧИСЛО(ПОИСК(«казачок»;A2));»11 казачок»;ЕСЛИ(ЕЧИСЛО(ПОИСК(«янтарный замок», если ячейка написанный прописными буквами
Для поиска на текущем секунд и сообщить, Sub: Вариант, работающий в нужно выделять 2006-й формуле правила. Данная
УРА!
ответили. К наименованию 3000 ячеек, например,
в Excel третий пробелы в нули в начале значение принимает верное. столбца В листа
замок»;A2));»10 янтарный замок»;»?»)) содержит текст «янтарный текст, начинающийся со листе или во помогла ли она
Tanya15 любой версии Excel год или группу функция возвращает частьДобавлено через 19 минут товара необходимо подтянуть «скобы, скрепки» иЧитайте так же: как
строке. ПОИСК(» «;A3;1) числа. Если ввести Ввожу руками, результат «списки». Для примераHugo121
замок» и если стандартного префикса, принятого всей книге можно
вам, с помощью: Мой пример=ЕСЛИ (ЕЧИСЛО (ПОИСК «C». строки, взятой сА главное так
категорию товара. Например, перечень товара Доп.заказ перевести число и находит первый пробел
вручную, Excel их не корректный… Что написала что должно: В вопросе Вы ячейка содержит текст
в организации, например выбрать в поле кнопок внизу страницы.Sub Кнопка2_Щелчок() («анонс»;A1))+ЕЧИСЛО (ПОИСК («икона»;A1))+ЕЧИСЛОВ решении данной задачи каждой ячейки столбца быстро ответили, просто наименование товара «Доп.
Скобы для степлера***, сумму прописью. слева (перед отчеством). удалит. Поэтому введем
делаю не так получиться. Выбирать фильтром как раз усложнили «казачок», то ввести
ИН_ или ТУ-.Искать Для удобства также
Dim i As (ПОИСК («суббота»;A1));A1;»») нам поможет дополнительная A, что указано невероятное чудо!!! Спасибо!
заказ Сироп ****»,
Доп. заказ СкобаСинтаксис функции ПОИСК: К найденному результату формулу: не понятно. Когда,
очень долго( — то «янтарный текст «11 казачок». Существует несколько способоввариант приводим ссылку на Single, j AsPS. Прошу прощение
текстовая функция в в первом аргументе. Будьте здоровы! а категория «Соусы, №24 (17000 ячеек)«искомый текст» — что добавляем единицу (+1).Если нужно вернуть прежние
ввожу «»,слежу, чтобыВитушка замок», то «замок Т.е. Если ячейка проверки ячейки наЛист оригинал (на английском
Single, s As за повтор. Не
формуле =НАЙТИ(). В Ссылка в первом
У нас имеется данные кетчупы, сиропы, томатная необходимо к перечню нужно найти; Получаем ту позицию, числовые значения (без стояла английская раскладка: пример прилагаю янтарный», поэтому я А2 содержи текст наличие в нейили языке) . Single заметил формулу Александра первом случаи формула аргументе должна быть для анализа производимой
паста» — то товара подтянуть категорию,
«просматриваемый текст» — где с которой будем нулей), то используем на клавиатуре.Витушка и предложил тот
«янтарный замок», то текста с учетомКнигаПредположим, что вы хотитеs = 0 в комментариях. Правда будет выглядеть так: относительной, так как продукции. Нам нужно
есть и сироп выбрав лишь часть искать; искать второй пробел. оператор «—»:Очень хочется понять: Формула
готовый макрос. И в ячейку В2
регистра.. убедиться, что столбецFor i = моя чуть короче.Для удобного выделения идентификаторов формула применяется к автоматически выделить все не первое слово, слова из категории«начальная позиция» — сЧасть формулы – ПОИСК(«Обратите внимание, что значения как работает этаКазанский формулу такую длинную. ввести текст «10Для выполнения этой задачиНажмите кнопку содержит текст, не 2 To 6 :-) с разной длинной каждой ячейке столбца изделия, которые были и окончание слова
за минусом окончания какой позиции начинать «;A3;ПОИСК(» «;A3;1)+1) – теперь отображаются в формула, в впрекрасно работает иНо если порядок янтарный замок» и используется функция СОВПАДНайти все номера. Или perhapsyouFor j =Вот еще формула текстовой строки товаров
A. Во втором выпущены в 2006 другое, что мешаетChe79 искать (по умолчанию находит второй пробел. числовом формате. целом, и где для Вашего примера
слов всегда правильный, если ячейка А2 .или необходимо найти все 1 To 6ЕСЛИ (СЧЁТЕСЛИ (A1;»*анонс*»)+СЧЁТЕСЛИ из группы «C»
CyberForum.ru
Функции для работы с текстом в Excel
аргументе функции указывается году. К сожалению, поиску. Есть возможность: – 1). Это будет конечная
Примеры функции ТЕКСТ в Excel
допускаешь ошибку…Формула не Код =ЕСЛИОШИБКА(ИНДЕКС(списки!B$1:B$6;ПОИСКПОЗ(ЛОЖЬ;ЕНД(ПОИСКПОЗ(«*»&списки!A$1:A$6&»*»;A2;));));»-«) то конечно всё содержи текст «казачок»,Примечание:Найти далее заказы, которые соответствуютIf Cells(i, j)
(A1;»*икона*»)+СЧЁТЕСЛИ (A1;»*суббота*»);A1;»») используем такую формулу: номер символа исходного в таблице недостает как то этоsweta212Если нужно учитывать регистр, позиция отчества.Отдельные текстовые функции и выдает ошибку, она
Витушка проще. то в ячейку Функция СОВПАД учитывает регистр,
. определенным Продавец. Если = «яблоко» Then
Tanya15Функция =НАЙТИ() выполняет поиск текста, с которого еще одного столбца свести? Использовала формулу, в описании у используется функция НАЙТИ.Далее из общей длины
их комбинации позволяют возвращает 0, если
: Я понимаю, чтоСтоп, кажется мне В2 ввести текст но не учитываетНайти все у вас нетs = s: Здравствуйте, подскажите, пожалуйста, фрагмента текста в должен начаться отрезок содержащего значения года=ПРОСМОТР(2;1/ПОИСК(классификатор!$H$2:$H$2617;D6);классификатор!$H$2:$H$2617)
Вас скобы, скрепки,Евгений8510 строки отнимается количество распределить слова из нет замены. я дурак. Мучаюсь очки пора доставать… «11 казачок».
различия в форматировании.списки каждого экземпляра проблемой верхний или + Cells(i, j
как правильно прописать ячейке Excel. Потом строки. В третьем
производства каждого изделия.
Функция разделения текста в Excel
нашла только 3000 степлеры, а во: Уважаемые форумчане, подскажите знаков с начала одной ячейки в
- Для удобства работы с уже час. Но Там небыло вариантаБуду благодарна за
- Для выполнения этой задачи элемента, который необходимо нижний регистр текста, + 1)
- код VBA. возвращает номер символа, аргументе указывается количество Но видно, что товаров из 17000, вложении чай с пожалуйста как решить
строки до второго отдельные ячейки: текстом в Excel мне не ввести «замок янтарный»?
помощь. используются функции СОВПАД найти, и позволяет существует несколько способов
End IfНеобходимо в диапазоне в котором был символов, которые нужно в фрагменте идентификатора в основном при сиропом и кетчупом задачу с текстом. пробела. Результат –ЛЕВСИМВ (текст; кол-во знаков) существуют текстовые функции. формулу массива(((Если не
Анастасия_П
IvanOK и или . сделать активной ячейки, проверки, если ячейкаNext j текстовых ячеек найти найдет текст, который взять после определенного (ID) изделия указывается
полном совпадении слов, и названия листовНа листе1, есть число символов справа,
– отображает заданное Они облегчают обработку сложно, можно вставить: Ураааа!!! Работает!!! Спасибо-преспасибо!!!:Примечание: выбрав нужное вхождение. содержит текст.Cells(i, 7) = ячейки которые содержат задан в первом (во втором аргументе) год производства. В но получила обратный
«категории» и «наименование». столбец «В» в которые нужно вернуть. число знаков с сразу сотен строк.
ее в файл? Всем всем всемАнастасия_П При вводе формулы в Можно сортировать результатыДля поиска текста можно s
слово, например «яблоко». аргументе. Во втором символа исходного текста.
Функция объединения текста в Excel
таком случае нам эффект — категория Куда что притягивать? котором текст, изФормула «для отчества» строится
начала ячейки; Рассмотрим некоторые из
А?Формула не дает, ближе к делу примере должны бытьНайти также использовать фильтр.s = 0 Т.е. есть ячейки аргументе указываем где В результате функция нужно выполнить поиск «Бра» подтянулась ко Нарисуйте желаемый результат него нужно извлечь
по тем жеПРАВСИМВ (текст; кол-во знаков)
них на примерах.
OlesyaSh вносить много аргументов…Когда давайте сюда пример формула массива. Послевсе, щелкнув заголовок.
Функция ПОИСК текста в Excel
Дополнительные сведения см.Next i с текстом «зеленое искать текст. А
=ПСТР() возвращает только по части текста всем товарам где вручную в нескольких часть текста в принципам:
– возвращает заданноеПреобразует числа в текст.: копируете формулу, вставляете «достраиваю» формулу, такHugo121 ввода формулы. НажмитеПримечание: в статье Фильтрация
End Sub яблоко», «красное яблоко», третий аргумент –
часть текста длинной в Excel. А встречались данные буквы
ячейках.
- столбец «С» ,Для объединения значений из
- количество знаков с Синтаксис: значение (числовое
- куда надо и и пишет, что: Можете переработать кучу клавишу F2 и
Чтобы прекратить процесс поиска, данных.
exceltable.com
Поиск части текста в ячейке
итогояблоко1арбуз25яблоко2526апельсин2апельсин26арбуз140зеленое яблоко 3яблоко24вишня8624яблоко «яблоко» и тд, это номер позиции 4 символа взятого
потом мы будем внутри слова, напримерbmv98rus а список нужного нескольких ячеек в конца ячейки; или ссылка на сразу же - слишком много аргументов… готовых решений из
нажмите клавиши CTRL нажмите клавишу ESC.Выполните следующие действия, чтобы арбуз 4апельсин28зеленое яблоко920красное
необходимо, что бы с какого символа
начиная с 5-ой использовать условное форматирование «собранный»: текста, находится на одну строку используется
ПОИСК (искомый текст; диапазон ячейку с формулой,
держите зажатыми CtrlДобавлено через 15 минут темы Поиск и + SHIFT +
Для выполнения этой задачи найти ячейки, содержащие яблоко5красное яблоко33апельсин320 он нашел всех вести поиск в буквы в каждой
с текстовыми функциямиPelenaChe79 листе2. Заранее благодарен оператор амперсанд (&)
для поиска; начальная дающей в результате
и Shift, нажимаетеФормула не дает выделение в таблице ВВОД. Microsoft Excel используется функция определенный текст.В итоге считает их. исходном тексте. Третий ячейки из столбца в формуле. Благодаря
CyberForum.ru
Поиск в диапазоне ячеек части текста из другого диапазона (Формулы/Formulas)
: На форуме есть, так там даже за помощь. или функция СЦЕПИТЬ. позиция) – показывает число); формат (для Enter. вносить много аргументов…Когда по нескольким параметрам вставляет фигурные скобкиЕТЕКСТВыделите диапазон ячеек, среди только «яблоко», а
V аргумент позволяет нам А. Это «2005» этому молниеносно реализуем тема про нечеткий помечено Offtop :-)snipeНапример, значения расположены в позицию первого появления отображения числа впотом протягиваете ее «достраиваю» формулу, такРекомендую моё в начале и
. которых требуется осуществить зеленые и красные: и что дальше смещаться по строке.
или «2006». После решение задачи. поиск Простая метрикаsweta212: разных столбцах (ячейках): искомого знака или виде текста). вниз. и пишет, чтоАнастасия_П конце формулу. ЕслиДля возвращения результатов для поиск. не учитывает. Необходимо, с этим делать Например, если в функции стоит операторПример таблицы производимой продукции:
сходства текстовых строк: bmv98rus, Che79, спасибо,Евгений8510Ставим курсор в ячейку, строки при просмотреСамая полезная возможность функциик тому же слишком много аргументов…: вот вложение формула не будет условия, которое можно
Чтобы выполнить поиск по чтобы считал по будете? идентификаторе 2 раза сравнения к значениюЧтобы на основе идентификатораПосмотрите результат с
что ответили. К,
где будут находиться слева направо
ТЕКСТ – форматирование Вам ответили наКазанскийHugo121 введена как формула указать с помощью всему листу, щелкните всем ячейкам вкак вариант таблицу используется символ «C». строки «2006». Если выделить изделия 2006-го одной из функций. наименованию товара необходимонаверное не тот объединенные три значения.При разделении текста в числовых данных для
другом форуме))))Урррааааа! Получилось.: Составьте на другом: Хотя для таких массива, ошибка #VALUE! функции любую ячейку. которых содержится слово загнать в массив В таком случае ячейка содержит такую года выпуска выполним
100%-го результата, конечно, подтянуть категорию товара. файлик прикрепили Вводим равно. Выбираем строке учитывается положение
объединения с текстовыми Просто чудеса. Но
листе таблицу соответствия 2-х условий можно возвращается. Дополнительные сведения
ЕслиНа вкладке «яблоко» и циклом перебирать
excelworld.ru
Поиск фрагментов текста в ячейке
третий аргумент пользователь часть текста значит шаги следующих действий: не будет, но Например, наименование товараЕвгений8510 первую ячейку с каждого знака. Пробелы данными. Без использования
все не так фрагмент-номер в ст. формулами сделать - о формулах массива.ГлавнаяКазанский . задает в зависимости ей будет присвоенВыделите диапазон ячеек A2:A10
как вариант… «Доп. заказ Сироп
: Да к сожалению
текстом и нажимаем показывают начало или
функции Excel «не просто, задача на А и В, вот начало:
читайте в статьеДля выполнения этой задачи
в группе: Tanya15, If Cells(i,
Пытливый
от ситуации. новый формат. и выберите инструмент:В формуле можно
CyberForum.ru
Условное форматирование по части текста в ячейке Excel
****», а категория не тот… приношу на клавиатуре &. конец искомого имени. понимает», как показывать самом деле сложнее. в ст. С=IF((FIND(«янтарный»,LOWER(A2),1)>0)+(FIND(«замок»,LOWER(A2),1)>0)=2,»10 янтарный замок»,»»)Сюда рекомендации и примеры используются функцииРедактирование j) like «*яблоко*»: Варианты: Воспользоваться методомТак как функция возвращаетАналогичным способом можно использовать «ГЛАВНАЯ»-«Стили»-«Условное форматирование»-«Создать правило». поиграться с последним «Соусы, кетчупы, сиропы, свои извинения уважаемые Затем – знакРаспределим с помощью функций числа, и преобразует Боялась что не «протяните» формулу, которая навесить обработку ошибки
формул массива.
Еслинажмите кнопку Then Find для диапазона.
- нужное число мы и другие текстовыеВыберите: «Использовать формулу для
- аргументом — % томатная паста» -
- коллеги. Прикрепляю нужный пробела, заключенный в имя, фамилию и их в базовый
- разберусь и сначала склеит эти данные. и ещё вложитьДля выполнения этой задачи,Найти и выделить
Tanya15 Вопрос — что
прекрасно используем ее функции в условном определения форматируемых ячеек». совпадения
то есть и
Функция ПСТР и ее пример в использования условном форматировании
файл. кавычки (“ “). отчество в разные формат. проблему озвучила попроще.В основной таблице аналогичный IF для используются функции Если,Поиски нажмите кнопку: Все так просто дальше с ними в качестве аргументов форматировании. Например, сЧтобы выполнить поиск частиНаташа Демчук сироп не первоеAleksSid Снова — &. столбцы.Покажем на примере. Допустим, А Может быть используйте такую формулу казачков. Поиски ЕЧИСЛО .иНайтиСпасибо! делать надо? для других функций помощью функции =ПРАВСИМВ() текста в ячейке: Помогите, пожалуйста, прописать слово, и окончание: Вариант. Код =ПРОСМОТР(2;1/ПОИСК(Лист2!$B$2:$B$9;B3);Лист2!$B$2:$B$9) И так последовательноВ первой строке есть нужно объединить текст получится вообще одной Код =ИНДЕКС(Лист1!$C$1:$C$99;ПОИСКПОЗ(ЛОЖЬ;ЕНД(ПОИСКПОЗ(«*»&Лист1!$A$1:$A$99&»*»;A2;));)) ЭтоНу или сПримечание:ЕЧИСЛО.Nordheimupd V, опередил (ПСТР и ПРАВСИМВ). мы можем экспонировать Excel, введите формулу: формулу. Видела похожие слова другое, чтоЕвгений8510 соединяем ячейки с
только имя и в строках и формулой обойтись. Смысл формула требует ввода допстолбцами сделать, чтоб В функции НАЙТИ учитывается.В поле: под ваш пример. с вопросом!
Помогите составить формулу: цветом определенную группу =ПСТР(A2;5;4)=»2006″ обращения к Вам мешает поиску. Есть: Огромное спасибо AleksSi, текстом и пробелы. фамилия, разделенные пробелом. числовые значения: в том, что как формула массива, голову меньше ломать
регистр букв.Примечание:НайтиSub test() DimNordheimЕсли среди текста товаров из партииНажмите на кнопку «Формат», за помощью, но возможность как то это то чтоПолучаем в одной ячейке Формула для извлеченияИспользование амперсанда без функции если в столбце т.е. нажатием Ctrl+Shift+Enter,
— в соседнийНа приведенном выше рисунке Функциявведите текст — i&, iCnt1&, iCnt2&,: Sub test() Dim
в ячейке A1 C. Для этого чтобы задать красный что-то у меня это свести? Использовала
нужно, красивое решение. объединенные значения: имени: =ЛЕВСИМВ(A2;ПОИСК(» «;A2;1)). ТЕКСТ дает «неадекватный» А листа «отчет» и отображается в столбец вытянуть казачков, формуле используются аргументы,поиска или номера —, arr(), ikey ‘1 i&, iCnt1&, iCnt2&, есть текст «Анонс» нужно использовать формулу: цвет заливки для не выходит сделать формулуAlexMИспользование функции СЦЕПИТЬ: Для определения второго результат: не нашлось фрагмента, фигурных скобках. затем в третий
указанные ниже.не учитывается регистр. вам нужно найти. вариант For Each arr() ‘1 вариант или «икона» или
exceltable.com
Поиск текста в ячейке excel
Здесь все просто функция
ячейки. И нажмите самостоятельно. Очень Надо=ПРОСМОТР(2;1/ПОИСК(классификатор!$H$2:$H$2617;D6);классификатор!$H$2:$H$2617): Если нужен диапазонС помощью кавычек в аргумента функции ЛЕВСИМВExcel вернул порядковый номер
соответствующего столбцу А
В таком виде собрать то, чтоФормула для поиска текста
Примечание:
Или выберите из ikey In ActiveSheet.UsedRange поиск на листе «суббота», то содержимое позволяет выбрать часть
ОК на всех Спасибо.
нашла только 3000 с запасом Код формуле можно добавить – количества знаков
для даты и листа «списки», просматривается она рассчитана на
без ошибок.
искомая строкаМы стараемся как раскрывающегося списка
If UCase(ikey.Value) Like For i = ячейки A1 скопировать
текста из ячейки открытых окнах.Суть задачи: надо товаров из 17000, =ПРОСМОТР(2;1/ПОИСК(Лист2!B$2:B$99;B3)/(Лист2!B$2:B$99<>»»);Лист2!B$2:B$99) Можно добавлять в конечное выражение
– используется функция
общий формат вместо столбец В, если
Поиск ячеек, содержащих определенное слова (VBA)
таблицу номеров длинойКстати, пример не: вы хотите проверить. можно оперативнее обеспечивать
Найти UCase(«*яблоко*») Then iCnt1 1 To 100 в ячейку B1 Excel, начиная сЭкспонированные цветом изделия 2006-го чтобы в столбец в основном при список на листе2, любой знак или ПОИСК. Она находит
денежного. Чтобы избежать не находится и до 99 записей. соответствует тексту вопроса
Ячейка вас актуальными справочнымипоследнего поиска. = ikey(1, 2)
If UCase(Cells(i, 1).Value)Пример строки правой стороны исходного года выпуска: Е на листе полном совпадении слов,
не меняя формулу. текст.
пробел в ячейке подобного результата, применяется в нем, то При необходимости поменяйте — пример проще.: ячейку, содержащую текст, материалами на вашемПримечание: + iCnt1 Next Like UCase(«яблоко») Thenmovie 0:00:35.00 Z:1-Анонс текста. Количество необходимыхДалее разберем принцип действия «ДАННЫЕ» попала соответствующая но получила обратныйФормулу можно поместитьФункция ПОИСК возвращает начальную А2, начиная слева. функция ТЕКСТ. Она столбец С. Если 99 на другое Я делал по который требуется проверить. языке. Эта страница В условиях поиска можно ikey MsgBox «На iCnt1 = iCnt1 0,35 Икона стиля символов указано во
формулы и ее статья расходов из
эффект — категория
в функцию ЕСЛИОШИБКА(), позицию искомого текстаФормула для извлечения фамилии: форматирует значения по
поможете, будет очень
число. вопросу
Анастасия_П переведена автоматически, поэтому
использовать подстановочные знаки. листе » &
+ 1 Next (Воскресенье 14.00).mp4 втором аргументе функции
модификации схожими текстовыми
листа «СТАТЬЯ». Соответствующая
«Бра» подтянулась ко на случай, если
(без учета регистра).
С помощью функции ПОИСК
заданию пользователя.
здорово!! Файл приложилаДобрыйАнастасия_ПВообще я не
: Добрый день! ее текст можетЧтобы задать формат для iCnt1 & « i ‘2 вариантСпасибо всем откинувшимся! ПРАВСИМВ. После чего функциями.
статья прописана в всем товарам где поиск не дал Например:
Excel определяет количествоФормула «для даты» теперь день!
: Все работает, благодарю формулист — наверняка
Помогите решить задачу. содержать неточности и поиска, нажмите кнопку ябл.» End Sub поиск в массивеПолосатый жираф алик все что возвращает столбце D на встречались данные буквы результата.Функция ПОИСК вернула позицию знаков для функции
planetaexcel.ru
выглядит так:
Поиск ключевых слов в тексте
Поиск ключевых слов в исходном тексте — одна из очень распространенных задач при работе с данными. Давайте рассмотрим её решение несколькими способами на следующем примере:
Предположим, что у нас с вами есть список ключевых слов — названия автомобильных марок — и большая таблица всевозможных запчастей, где в описаниях иногда могут встречаться один или сразу несколько таких брендов, если запчасть подходит больше, чем к одной марке автомобиля. Наша задача состоит в том, чтобы найти и вывести все обнаруженные ключевые слова в соседние ячейки через заданный символ-разделитель (например, запятую).
Способ 1. Power Query
Само-собой, сначала превращаем наши таблицы в динамические («умные») с помощью сочетания клавиш Ctrl+T или команды Главная — Форматировать как таблицу (Home — Format as Table), даём им имена (например Марки и Запчасти) и загружаем по очереди в редактор Power Query, выбрав на вкладке Данные — Из таблицы/диапазона (Data — From Table/Range). Если у вас старые версии Excel 2010-2013, где Power Query установлена как отдельная надстройка, то нужная кнопка будет на вкладке Power Query. Если у вас совсем новая версия Excel 365, то кнопка Из таблицы/диапазона называется там теперь С листа (From Sheet).
После загрузки каждой таблицы в Power Query возвращаемся обратно в Excel командой Главная — Закрыть и загрузить — Закрыть и загрузить в… — Только создать подключение (Home — Close & Load — Close & Load to… — Only create connection).
Теперь создадим дубликат запроса Запчасти, щёлкнув по нему правой кнопкой мыши и выбрав команду Дублировать запрос (Duplicate query), затем переименуем получившийся запрос-копию в Результаты и дальше будем работать уже с ним.
Логика действий следующая:
- На вкладке Добавление столбца выбираем команду Настраиваемый столбец (Add column — Custom column) и вводим формулу =Марки. После нажатия на ОК получим новый столбец, где в каждой ячейке будет вложенная таблица со списком наших ключевых слов — марок автопроизводителей:
- Кнопкой с двойными стрелками в шапке добавленного столбца разворачиваем все вложенные таблицы. Строки с описаниями запчастей при этом размножатся кратно количеству марок, и мы получим все возможные пары-сочетания «запчасть-марка»:
- На вкладке Добавление столбца выбираем команду Условный столбец (Conditional column) и задаём условие на проверку вхождения ключевого слова (марки) в исходный текст (описание запчасти):
- Чтобы поиск был регистроНЕчувствительный, добавляем вручную в строке формул третий аргумент Comparer.OrdinalIgnoreCase к функции проверки вхождения Text.Contains (если строки формул не видно, то её можно включить на вкладке Просмотр):
- Фильтруем получившуюся таблицу, оставляя только единички в последнем столбце, т.е. совпадения и удаляем ненужный больше столбец Вхождения.
- Группируем одинаковые описания командой Группировать по на вкладке Преобразование (Transform — Group by). В качестве агрегирующей операции выбираем Все строки (All rows). На выходе получаем столбец с таблицами, куда собраны все подробности по каждой запчасти, включая необходимые нам марки автопроизводителей:
- Чтобы извлечь марки для каждой запчасти, добавляем еще один вычисляемый столбец на вкладке Добавление столбца — Настраиваемый столбец (Add column — Custom column) и используем формулу, состоящую из таблицы (они у нас располагаются в столбце Подробности) и имени извлекаемого столбца:
- Щёлкаем по кнопке с двойными стрелками в шапке получившегося столбца и выбираем команду Извлечь значения (Extract values), чтобы вывести марки через любой желаемый символ-разделитель:
- Удаляем ненужный больше столбец Подробности.
- Чтобы добавить к получившейся таблице исчезнувшие из неё запчасти, где в описаниях не было найдено ни одной марки — выполним процедуру объединения запроса Результат с исходным запросом Запчасти кнопкой Объединить на вкладке Главная (Home — Merge queries). Тип соединения — Внешнее соединение справа (Right outer join):
- Останется удалить лишние столбцы и переименовать-переместить оставшиеся — и наша задача решена:
Способ 2. Формулы
Если у вас версия Excel 2016 или новее, то нашу проблему можно весьма компактно и изящно решить с помощью новой функции ОБЪЕДИНИТЬ (TEXTJOIN):
Логика работы этой формулы проста:
- Функция ПОИСК (FIND) ищет вхождение по очереди каждой марки в текущее описание запчасти и выдаёт либо порядковый номер символа, начиная с которого марка была найдена, либо ошибку #ЗНАЧ! если марки в описании нет.
- Затем при помощи функции ЕСЛИ (IF) и ЕОШИБКА (ISERROR) мы заменяем ошибки на пустую текстовую строку «», а порядковые номера символов — на сами названия марок.
- Полученный массив из пустых ячеек и найденных марок собирается в единую строку через заданный символ-разделитель с помощью функции ОБЪЕДИНИТЬ (TEXTJOIN).
Сравнение быстродействия и буферизация запроса Power Query для ускорения
Для тестирования быстродействия возьмем в качестве исходных данных таблицу из 100 000 описаний запчастей. На ней получаем следующие результаты:
- Время пересчета формулами (Способ 2) — 9 сек. при первом копировании формулы на весь столбец и 2 сек. при повторном (сказывается буферизация, видимо).
- Время обновления запроса Power Query (Способ 1) гораздо хуже — 110 сек.
Само-собой, многое зависит от «железа» отдельно взятого ПК и установленной версии Office и обновлений, но общая картина, думаю, понятна.
Для ускорения запроса Power Query давайте буферизуем таблицу-справочник Марки, т.к. она у нас не меняется в процессе выполнения запроса и постоянно пересчитывать её (как это де-факто делает Power Query) не нужно. Для этого используем функцию Table.Buffer из встроенного в Power Query языка М.
Для этого откроем запрос Результаты и на вкладке Просмотр нажмём на кнопку Расширенный редактор (View — Advanced Editor). В открывшемся окне добавим строку с новой переменной Марки2, которая будет буферизованной версией нашего справочника автопроизводителей и используем эту новую переменную далее в следующей команде запроса:
После такой доработки скорость обновления нашего запроса возрастает почти в 7 раз — до 15 сек. Совсем другое дело
Ссылки по теме
- Нечёткий текстовый поиск в Power Query
- Массовая замена текста формулами
- Массовая замена текста в Power Query функцией List.Accumulate