ПОИСК, ПОИСКБ (функции ПОИСК, ПОИСКБ)
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 только текст, заключенный в двойные кавычки. |
босс |
Нужна дополнительная помощь?
Находим позицию третьего, четвертого и т.д. вхождения символа в слове (в текстовой строке).
Предположим, в ячейке
А5
имеется текстовая строка:
МАМА МЫЛа РАМУ
(см.
файл примера
).
Формула:
=НАЙТИ(СИМВОЛ(1);ПОДСТАВИТЬ(A5;»А»;СИМВОЛ(1);3))
найдет позицию
третьего
вхождения символа «А»
с учетом регистра
(9).
Рассмотрим подробнее. Функция
ПОДСТАВИТЬ()
заменяет третье вхождение символа «А» на символ с кодом ASCII =1 (заведомо нет в текстовой строке). Затем функция
НАЙТИ()
находит его и выводит его позицию. Если третьего вхождения не обнаружено, то будет выдана ошибка.
Формула без учета регистра:
=НАЙТИ(СИМВОЛ(1);ПОДСТАВИТЬ(СТРОЧН(A5);»а»;СИМВОЛ(1);3))
О подсчете вхождений символов можно прочитать
здесь
.
Формула:
=НАЙТИ(СИМВОЛ(1);ПОДСТАВИТЬ(A5;»МА»;СИМВОЛ(1);2))
найдет позицию
второго
вхождения подстроки «МА» с учетом регистра (3).
О подсчете вхождений последовательности символов можно прочитать
здесь
.
Skip to content
В этой статье объясняется с примерами формул, как использовать функцию ПОИСКПОЗ в Excel. Также вы узнаете, как улучшить формулы поиска, создав динамическую формулу с функциями ВПР и ПОИСКПОЗ.
В Microsoft Excel существует множество различных функций, которые могут помочь вам найти определенное значение в диапазоне ячеек, и ПОИСКПОЗ (MATCH на английском) — одна из них. По сути, она определяет относительное положение элемента в массиве значений. Однако функция ПОИСКПОЗ может делать гораздо больше.
- Функция ПОИСКПОЗ — пошаговая инструкция
- Поиск частичного совпадения с подстановочными знаками
- ПОИСКПОЗ с учетом регистра
- ПОИСКПОЗ и несколько условий
- Как сравнить столбцы при помощи ПОИСКПОЗ
- Совместное использование ВПР и ПОИСКПОЗ
- Использование ГПР и ПОИСКПОЗ
Функция ПОИСКПОЗ Excel — пошаговая инструкция
Функция ПОИСКПОЗ в Excel ищет указанное значение в массиве и возвращает относительное положение этого значения.
Рассмотрим пошагово, как составить формулу ПОИСКПОЗ:
ПОИСКПОЗ(искомое_значение; массив_поиска, [тип_совпадения])
Шаг 1. Искомое_значение (обязательный аргумент) — значение, которое вы хотите найти. Это может быть число, текстовое или логическое значение, а также ссылка на ячейку.
Шаг 2. Массив_поиска (обязательно) — диапазон ячеек для поиска.
Шаг 3. Указываем Тип_совпадения (необязательно) — определяет тип соответствия. Это может быть одно из следующих значений: 1, 0, -1. Аргумент, установленный в 0, возвращает только точное совпадение, в то время как два других значения допускают приблизительное совпадение.
- 1 или опущено (по умолчанию) — найти наибольшее значение в массиве поиска, которое меньше или равно значению поиска. Требуется сортировка массива поиска в порядке возрастания, от меньшего к большему или от А до Я.
- 0 — найти первое значение в массиве, точно равное искомому значению. Никакой сортировки не требуется.
- -1 — найти наименьшее значение в массиве, которое больше или равно искомому значению. Массив поиска должен быть отсортирован в порядке убывания, от наибольшего к наименьшему или от Я до A.
Чтобы лучше понять функцию ПОИСКПОЗ, давайте составим простую формулу на основе этих данных: имена учащихся в столбце А и их экзаменационные баллы в столбце В, отсортированные от наибольшего к наименьшему. Чтобы узнать, какое место среди других занимает конкретный ученик (скажем, Елена ), используйте эту простую формулу:
=ПОИСКПОЗ(“Елена”; A2:A8;0)
При желании вы можете поместить искомое значение в какую-либо ячейку (E1 в этом примере) и сослаться на эту ячейку в своей формуле:
=ПОИСКПОЗ(E1; A2:A8;0)
Как вы видите на скриншоте выше, имена расположены не по алфавиту, а потому мы устанавливаем аргументу тип_совпадения значение 0 (точное соответствие). Ведь только этот вариант не требует сортировки в массиве поиска.
Технически формула ПОИСКПОЗ возвращает относительное положение «Елена» в списке. Но поскольку оценки отсортированы от наибольшей суммы к наименьшей, это также говорит нам о том, что Елена занимает пятое место среди 8 учащихся.
4 вещи, которые вы должны знать о функции ПОИСКПОЗ
Как вы только что убедились, использовать ПОИСКПОЗ в Excel достаточно просто. Однако, как и в случае с почти любой другой функцией Excel, есть несколько особенностей, о которых вам следует помнить:
- Функция ПОИСКПОЗ возвращает относительное положение искомого значения в массиве, а не само значение.
- ПОИСКПОЗ нечувствительна к регистру , то есть не различает строчные и прописные символы при работе с текстовыми значениями.
- Если искомый массив содержит несколько вхождений искомого значения, то возвращается позиция первого найденного значения.
- Если искомое значение не найдено в массиве поиска, возвращается ошибка #Н/Д.
Как использовать ПОИСКПОЗ в Excel — примеры формул
Теперь, когда вы знаете основные способы использования функции ПОИСКПОЗ Excel, давайте обсудим еще несколько примеров формул, чуть более сложных.
Частичное совпадение с подстановочными знаками
Как и многие другие функции, ПОИСКПОЗ понимает следующие подстановочные знаки :
- Вопросительный знак (?) — заменяет любой одиночный символ
- Звездочка (*) — заменяет любую последовательность символов
Примечание. Подстановочные знаки можно использовать только тогда, если для параметра тип_совпадения установлено значение 0.
Формула поиска с подстановочными знаками полезна в ситуациях, когда требуется сопоставить не всю текстовую строку, а только некоторые символы или её часть. Чтобы проиллюстрировать это, рассмотрим следующий пример.
Предположим, у вас есть данные о продажах напитков за последний месяц. Вы хотите найти относительную позицию определенного наименования в списке (отсортированном по суммам продаж в порядке убывания), но не можете точно вспомнить полное наименование, хотя помните несколько первых символов.
Предположим, что наименования товаров находятся в диапазоне A2:A11, и вы ищете имя, начинающееся с «доб». Формула выглядит следующим образом:
=ПОИСКПОЗ(«доб*»; A2:A11;0)
Чтобы сделать нашу формулу более универсальной, вы можете ввести искомое значение в какую-либо ячейку (E1 в этом примере) и соединить эту ячейку с подстановочным знаком, например:
=ПОИСКПОЗ(E1&»*»; A2:A11;0)
Как показано на скриншоте ниже, формула возвращает 4, что является позицией «Добрый экзотик»:
Обратите внимание, что напитков «Добрый» в нашем массиве целых три. Но формула останавливает поиск, как только будет найдено первое подходящее соответствие.
Чтобы заменить только один символ в искомом значении, используйте подстановочный знак «?».
Формула ПОИСКПОЗ с учетом регистра
Как упоминалось ранее, функция ПОИСКПОЗ не различает символы верхнего и нижнего регистра.
Чтобы создать формулу поиска с учетом регистра, используйте ПОИСКПОЗ в сочетании с функцией СОВПАД, которая точно сравнивает содержимое ячеек, включая регистр символов.
Вот общая формула с учетом регистра для сопоставления данных:
=ПОИСКПОЗ(ИСТИНА;СОВПАД(искомый массив ; искомое значение );0)
Формула работает по следующей логике:
- Функция СОВПАД (EXACT в английской версии) сравнивает значение с каждым элементом массива поиска. Если сравниваемые ячейки точно равны, функция возвращает значение ИСТИНА, в противном случае — ЛОЖЬ.
- Затем функция ПОИСКПОЗ сравнивает ИСТИНА (которое является ее искомым_значением ) с каждым значением в массиве, возвращаемом функцией СОВПАД, и возвращает позицию первого совпадения.
Пожалуйста, имейте в виду, что это формула массива , которая требует нажатия Ctrl + Shift + Enter
при завершении ее ввода.
Предполагая, что искомое значение находится в ячейке E1, а массив поиска — A2:A9, формула выглядит следующим образом:
=ПОИСКПОЗ(ИСТИНА;СОВПАД(A2:A9;E1);0)
На скриншоте показана формула поиска соответствия с учетом регистра в Excel:
Как видите, формула различает регистр букв и по этой причине «А-201» было признано неподходящим.
ПОИСКПОЗ и несколько условий
Выше мы рассматривали функцию ПОИСКПОЗ с одним условием. Но на практике очень часто критериев поиска бывает несколько. Давайте рассмотрим такой случай.
Предположим, у нас есть список продаж отдельных товаров в нескольких регионах. Нужно найти первую подходящую позицию в списке для нужного товара и заданного региона.
Вот формула ПОИСКПОЗ для нескольких условий:
=ПОИСКПОЗ(1;(B2:B12=G1)*(C2:C12=G2);0)
Давайте разбираться.
Наши два условия мы записываем в виде выражения (B2:B12=G1)*(C2:C12=G2). Первое условие (B2:B12=G1) означает, что мы сравниваем каждое из значений в столбце «Регион» с целью «Север», которая записана в G1. Получаем массив {ЛОЖЬ:ИСТИНА:ИСТИНА:ИСТИНА:ЛОЖЬ:ЛОЖЬ:ЛОЖЬ:ЛОЖЬ:ИСТИНА:ЛОЖЬ:ЛОЖЬ}
Аналогично каждый из товаров сравниваем с «Яблоки» из G2. Аналогично получаем результат {ИСТИНА:ЛОЖЬ:ЛОЖЬ:ИСТИНА:ЛОЖЬ:ИСТИНА:ЛОЖЬ:ЛОЖЬ:ИСТИНА:ЛОЖЬ:ИСТИНА}.
После перемножения этих массивов получаем матрицу единиц и нулей: {0:0:0:1:0:0:0:0:1:0:0}
Здесь единицы означают те позиции, в которых оба условия выполняются.
И вот в этом массиве функция ПОИСКПОЗ ищет первую единицу. И находит ее в 4-й позиции.
Обратите внимание, что в наших данных есть две строки, в которых выполняются оба условия — товар и регион. Но функция ПОИСКПОЗ ищет в массиве только первое совпадение и после этого поиск останавливается.
Думаю, вы понимаете, что совершенно аналогичным образом можно вести поиск по трём и большему количеству условий.
Номер позиции в данном случае для нас может быть не так уж и важен сам по себе. Но зато, зная его, мы можем при помощи функции ИНДЕКС извлечь значение из любого столбца в этой позиции. Более подробно об этом читайте: ИНДЕКС+ПОИСКПОЗ с несколькими условиями.
Как сравнить столбцы при помощи ПОИСКПОЗ
Проверка двух списков на совпадения и различия — одна из наиболее распространенных задач в Excel, и ее можно выполнить различными способами. Формула ЕНД/ПОИСКПОЗ является одним из них:
ЕСЛИ(ЕНД(ПОИСКПОЗ( 1-е значение в Списке1 , Списке2 , 0)), «Нет в Списке 1», «»)
Для любого значения списка 2, которого нет в списке 1, формула возвращает « Нет в списке 1 ».
Рассмотрим пошагово:
- Функция ПОИСКПОЗ ищет значение из списка 1 в списке 2. Если значение найдено, оно возвращает его относительное положение, в противном случае получается ошибка #Н/Д.
- Функция ЕНД в Excel выполняет только одну работу — проверяет наличие ошибок #Н/Д (что означает «недоступно»). Если обрабатываемое ею значение является ошибкой #Н/Д, функция возвращает значение ИСТИНА, в противном случае – ЛОЖЬ. В нашем случае ИСТИНА означает, что значение из списка 1 не найдено в списке 2 (т. е. функция ПОИСКПОЗ возвращает ошибку).
- Поскольку вам может быть не слишком понятным видеть ИСТИНА для значений, которые не отображаются в списке 1, вы оборачиваете функцию ЕСЛИ вокруг ЕНД, чтобы вместо ИСТИНА отображалось « Нет в списке 1 » или любой другой текст, который вы хотите.
Например, чтобы сравнить значения в столбце B со значениями в столбце A, формула может быть записана так (где B2 — самая верхняя ячейка):
=ЕСЛИ(ЕНД(ПОИСКПОЗ(B2;A:A;0)); «Нет в списке 1»; «»)
Как вы помните, функция ПОИСКПОЗ в Excel сама по себе нечувствительна к регистру. Чтобы она различала регистр символов, вставьте функцию СОВПАД (EXACT по английски) в аргумент массив_поиска и не забудьте нажать Ctrl + Shift + Enter
, чтобы ввести эту формулу массива :
{=ЕСЛИ(ЕНД(ПОИСКПОЗ(ИСТИНА; СОВПАД(A:A; B2);0)); «Нет в списке 1»; «»)}
На следующем рисунке показаны обе формулы в действии:
Быть может, вам также будет интересен этот материал: 5 способов сравнения ячеек в Excel.
Совместное использование ВПР и ПОИСКПОЗ
В этом примере предполагается, что у вас уже есть базовые знания о функции ВПР в Excel . И если вы работали с ВПР, то есть вероятность, что вы столкнулись с ее многочисленными ограничениями (подробный обзор которых можно найти в статье Почему не работает функция ВПР в Excel ) и ищете более надежную и универсальную альтернативу.
Один из самых досадных недостатков ВПР заключается в том, что она перестает корректно работать после вставки или удаления столбца в таблице поиска. Это происходит потому, что функция ВПР извлекает совпадающее значение на основе указанного вами номера возвращаемого столбца (номер индекса). Поскольку номер индекса «жестко запрограммирован» в формуле, Excel не может изменить его, когда в таблицу добавляются или удаляются новые столбцы.
Функция ПОИСКПОЗ в Excel работает с относительным положением искомого значения, что идеально подходит для аргумента номер_стролбца функции ВПР. Другими словами, вместо указания возвращаемого столбца в виде статического числа вы используете ПОИСКПОЗ, чтобы найти текущую позицию этого столбца.
Чтобы упростить понимание, давайте снова воспользуемся таблицей с экзаменационными баллами студентов (аналогичной той, которую мы использовали в начале этой статьи). Но на этот раз мы будем получать реальную оценку, а не ее относительное положение.
Предполагая, что искомое значение находится в ячейке F1, значения таблицы расположены в $A$1:$C$8 (рекомендуется зафиксировать его с помощью абсолютных ссылок на ячейки, если вы планируете копировать формулу), выражение выглядит следующим образом:
=ВПР($G$1;$A$1:$С$8; 2; ЛОЖЬ)
Третий аргумент ( номер столбца ) имеет значение 2, потому что результат Теста 1 , который мы хотим получить, является вторым столбцом в таблице. Как вы можете видеть на скриншоте ниже, эта обычная формула ВПР работает хорошо.
Но только до тех пор, пока вы не вставите или не удалите какие-то столбцы:
Как видите, если мы вставляем дополнительный столбец, то формула теперь извлекает неверные данные. Она по-прежнему ссылается на второй столбец, в то время как данные Тест 1 сместились в третий.
Чтобы предотвратить подобные вещи, вы можете сделать свою формулу ВПР более гибкой, включив в нее функцию ПОИСКПОЗ:
ПОИСКПОЗ($F$2;$A$1:$С$1;0)
Где:
- F2 — это искомое значение, которое в точности совпадает с именем возвращаемого столбца, т. е. столбца, из которого вы хотите извлечь значение ( Тест 1 в этом примере).
- A1:C1 — массив поиска, содержащий заголовки таблицы.
А теперь запишите эту формулу в аргумент номер_столбца вашей формулы ВПР, например:
=ВПР($G$1;$A$1:$D$8; ПОИСКПОЗ($F$2;$A$1:$С$1;0); ЛОЖЬ)
И убедитесь, что формула работает безупречно, независимо от того, сколько столбцов вы добавляете или удаляете.
Вставляем столбец с итоговым тестом:
Формула автоматически изменяется и продолжает работать, возвращая верный результат:
=ВПР($G$1;$A$1:$D$8; ПОИСКПОЗ($F$2;$A$1:$D$1;0); ЛОЖЬ)
Использование ГПР и ПОИСКПОЗ
Аналогичным образом вы можете использовать функцию ПОИСКПОЗ в Excel, чтобы улучшить свои формулы ГПР . Общий принцип, по сути, такой же, как и в случае ВПР: вы используете функцию ПОИСКПОЗ, чтобы получить относительное положение возвращаемого столбца, и передаете это число аргументу номер_строки вашей формулы ГПР.
Предположим, что искомое значение находится в ячейке B5, данные таблицы — B1:H3, имя возвращаемой строки (значение поиска для ПОИСКПОЗ) — в ячейке A6, а заголовки строк — A1:A3.
Тогда формула выглядит следующим образом:
=ГПР(B5;B1:H3;ПОИСКПОЗ(A6; A1:A3;0);ЛОЖЬ)
Как вы только что видели, комбинация ВПР/ГПР и ПОИСКПОЗ, безусловно, является улучшением по сравнению с обычными формулами. Однако функция ПОИСКПОЗ не устраняет всех их ограничений и недостатков. В частности, эта формула ВПР по-прежнему не может делать «левый поиск», а ГПР не может выполнять поиск ни в одной строке, кроме самой верхней.
Чтобы преодолеть вышеуказанные (и некоторые другие) ограничения, научитесь использовать комбинацию ИНДЕКС+ПОИСКПОЗ, которая обеспечивает действительно мощный и универсальный способ поиска в Excel, превосходящий ВПР и ГПР во многих отношениях.
Подробное руководство и примеры формул можно найти в ИНДЕКС и ПОИСКПОЗ в Excel — лучшей альтернативе ВПР .
Вот как можно использовать формулы ПОИСКПОЗ в Excel для быстрого поиска в массиве данных. Надеемся, что примеры, рассмотренные в этом руководстве, окажутся полезными в вашей работе.
Основное назначение этой функции в том, чтобы искать позицию заданного элемента в наборе значений. Чаще всего она применяется для поиска порядкового номера ячейки в диапазоне, где лежит нужное нам значение.
Синтаксис этой функции следующий:
=ПОИСКПОЗ(Что_ищем; Где_ищем; Режим_поиска)
где
- Что_ищем — это значение, которое надо найти
- Где_ищем — это одномерный диапазон или массив (строка или столбец), где производится поиск
- Режим_поиска — как мы ищем: точно (0), с округлением в большую строну (-1) или в меньшую сторону (1)
Давайте рассмотрим несколько полезных вариантов ее применения на практике.
Точный поиск
Классический сценарий — поиск точного текстового совпадения для нахождения позиции нужного нам текста или числа в списке:
Поиск первой или последней текстовой ячейки
Если в качестве искомого значения задать звездочку, то функция будет искать первую ячейку с текстом и выдавать её позицию. Для поиска последней текстовой ячейки можно изменить третий аргумент Режим_поиска с нуля на минус 1:
Числа и пустые ячейки в этом случае игнорируются.
Поиск ближайшего числа или даты
Если последний аргумент задать равным 1 или -1, то можно реализовать поиск ближайшего наименьшего или наибольшего числа. Таблица при этом обязательно должна быть отсортирована по возрастанию или убыванию соответственно. В общем и целом, это чем-то похоже на интервальный просмотр у функции ВПР (VLOOKUP), но там возможен только поиск ближайшего наименьшего, а здесь — есть выбор.
Например, нам нужно выбрать генератор из прайс-листа для расчетной мощности в 47 кВт. Если последний аргумент задать равным 1 и отсортировать таблицу по возрастанию, то мы найдем ближайшую наименьшую по мощности модель (Зверь):
Если же третий аргумент равен -1 и таблица отсортирована по убыванию, то мы найдем ближайшую более мощную модель (Бомба):
Связка функций ПОИСКПОЗ и ИНДЕКС
Очень часто функция ПОИСКПОЗ используется в связке с другой крайне полезной функцией — ИНДЕКС (INDEX), которая умеет извлекать данные из диапазона по номеру строки-столбца, реализуя, фактически, «левый ВПР».
Так, в предыдущем примере получить не номер, а название модели генератора можно очень легко:
Ну, и поскольку Excel внутри хранит и обрабатывает даты как числа, то подобный подход на 100% работает и с датами. Например, мы можем легко определить на каком этапе сейчас находится наш проект:
Принципиальное ограничение функции ПОИСКПОЗ состоит в том, что она умеет искать только в одномерных массивах (т.е. строчке или столбце), но никто не запрещает использовать сразу два ПОИСКПОЗа вложенных в ИНДЕКС, чтобы реализовать двумерный поиск по строке и столбцу одновременно:
Ссылки по теме
- 5 вариантов применения функции ИНДЕКС (INDEX)
- Интервальный просмотр с помощью функции ВПР (VLOOKUP)
- Поиск последнего значения в строке или столбце
- Как создать авторастягивающийся диапазон с автоподстройкой размеров
Содержание материала
- Пример функции ПОИСКПОЗ в Excel без функции ИНДЕКС
- Видео
- Функция ВПР с несколькими условиями критериев поиска в Excel
- Сочетание с функцией ПОИСКПОЗ
- Функция ПОИСКПОЗ в Excel – синтаксис и использование
- Функция ПОИСКПОЗ в Excel – Пример использования функции ПОИСКПОЗ в Excel
- Особенности функции ПОИСКПОЗ Excel
- Примеры
- Функция ИНДЕКС для массивов
- Поиск позиций ВСЕХ текстовых значений, удовлетворяющих критерию
- Поиск позиции в массивах с текстовыми значениями
- Поиск значений с помощью функций ВПР, ИНДЕКС и ПОИСКПОЗ
- Использование функции ГПР
- Одновременное использование функций ИНДЕКС и ПОИСКПОЗ
- Еще о функциях поиска
- Функция ИНДЕКС в Excel
- Правильное написание
- Пример использования функции ПОИСКПОЗ
Пример функции ПОИСКПОЗ в Excel без функции ИНДЕКС
Во многих поисковых формулах очень часто приходится использовать функцию ПОИСКПОЗ как вспомогательную в комбинациях с другими функциями такими как: ИНДЕКС, ВПР, ГПР и др. Но какую пользу может приносить данная функция работая самостоятельно. Из самого названия функции ПОИСКПОЗ понятно, что ее главная задача заключается в определении позиции исходного значения, которое содержит диапазон ячеек или таблица. Применять эту функцию очень просто для диапазонов или таблиц с одним столбцом или с одной строкой. Поэтому сразу усложним задачу и на конкретном примере проиллюстрируем как применять функцию ПОИСКПОЗ для таблицы с двумя столбцами и более.
Видео
Функция ВПР с несколькими условиями критериев поиска в Excel
Функция ВПР (Вертикальный ПРосмотр) ищет по таблице с данными и на основе критериев запроса поиска, возвращает соответствующее значение с определенного столбца. Очень часто необходимо в запросе поиска использовать сразу несколько условий. Но по умолчанию данная функция не может обработать более одного условия. Поэтому следует использовать весьма простую формулу, которая позволит расширить возможности функции ВПР по нескольким столбцам одновременно.
Сочетание с функцией ПОИСКПОЗ
Теперь давайте перейдем к более сложным задачам, выполняемым с помощью комбинированного использования оператора ИНДЕКС с другими функциями, например, с ПОИСКПОЗ (довольно часто эти функции используются вместе).
Оператор ПОИСКПОЗ возвращает положение указанного значения в выделенном диапазоне ячеек.
Формула функции выглядит следующим образом:
=ПОИСКПОЗ(Искомое_значение,Просматриваемый_массив,[Тип_сопоставления])
.
Давайте “пробежимся” по аргементам функции:
- Искомое значение – то значение, которе мы хотим найти в выделенном диапазоне;
- Просматриваемый массив – область ячеек, в которой мы будем искать искомое значение;
- Тип сопоставления – с помощью данного аргумента (не является обязательным) можно задать точность поиска.
Использование ПОИСКПОЗ позволяет автоматически заполнить аргументы “Номер строки” и/или “Номер столбца” функции ИНДЕКС.
Чтобы было нагляднее, давайте разберемся, как это работает на практическом примере. Для этого нам понадобится все та же таблица. Также, рядом с ней у нас есть небольшая вспомогательная таблица, в которой отведено место для одного наименования и его стоимости.
Наша задача – используя ИНДЕКС и ПОИСКПОЗ добавить в ячейку со стоимостью (G2) такую функцию, которая будет выводить конкретное значение в зависимости от того, что будет указано в ячейке с наименованием рядом.
- Для начала, заполняем ячейку с наименованием. Можно просто скопировать и вставить значение из основной таблицы.
- Теперь встаем в ячейку, в которой планируем отображать результат, и жмем кнопку “Вставить функцию” (fx).
- Выбираем функцию ИНДЕКС из списка операторов.
- Выбираем список аргументов для массива и жмем OK.
- Приступаем к заполнению аргументов:
- Таким образом, мы получаем в выбранной ячейке нужный результат, а именно цену указанной рядом позиции.
- Так как информация “подтягивается” с помощью формулы, изменение цены соответствующей позиции в основной таблице немедленно отразится в данной ячейке.
- Также, если мы изменим наименование позиции во вспомогательной таблице, ее цена автоматически будет заполнена из основной.
Функция ПОИСКПОЗ в Excel – синтаксис и использование
Функция ПОИСКПОЗ в Excel ищет заданное значение в диапазоне ячеек и возвращает относительное положение этого значения.
Синтаксис формулы ПОИСКПОЗ выглядит следующим образом:
Искомое_значение (обязательный аргумент) – значение, которое вы хотите найти. Это может быть числовое, текстовое или логическое значение, а также ссылка на ячейку.
Просматриваемый_массив (обязательный аргумент) – диапазон ячеек для поиска.
Тип_сопоставления (необязательный аргумент) – определяет тип соответствия. Это может быть одно из следующих значений: 1, 0, -1.
- 1 или отсутствует (по умолчанию) – находит наибольшее значение в массиве, которое меньше или равно значению поиска. Массив поиска должен быть отсортирован в порядке возрастания, от самого маленького до большого или от A до Z.
- 0 – находит первое значение в массиве, которое в точности равно значению поиска. Сортировка не требуется.
- -1 – находит наименьшее значение в массиве, которое больше или равно значению поиска. Массив поиска должен быть отсортирован в порядке убывания, от самого большого до самого маленького или от Z до A.
Чтобы лучше разобраться в данной функции, давайте напишем простую формулу ПОИСКПОЗ, основанную на следующих данных: фамилии студентов в столбце A и их баллы по экзаменам в столбце B, отсортированные от самых высоких до самых низких. Чтобы узнать, где среди других находится конкретный студент (например, студентка Виноградова), используйте эту простую формулу:
=ПОИСКПОЗ(E1; A2:A8; 0)
При желании вы можете поместить значение поиска в ячейку (E1 в данном примере) и сослаться на эту ячейку в формуле ПОИСКПОЗ Excel:
Функция ПОИСКПОЗ в Excel – Пример использования функции ПОИСКПОЗ в Excel
Как вы видите на изображении выше, фамилии студентов вводятся в произвольном порядке, поэтому мы устанавливаем аргумент тип_сопоставления равным 0 (точное совпадение), поскольку только этот тип соответствия не требует сортировки значений в массиве поиска. Технически формула ПОИСКПОЗ возвращает относительное положение студентки Виноградовой в исследуемом диапазоне. Но поскольку оценки сортируются от самых высоких до самых низких, это также говорит нам о том, что Виноградова пятая по счету среди всех учеников.
Особенности функции ПОИСКПОЗ Excel
Как вы только что видели, использовать ПОИСКПОЗ в Excel легко. Однако, как и у любой функции Excel, у нее есть несколько особенностей, о которых следует знать:
- Функция ПОИСКПОЗ возвращает относительное положение значения поиска в массиве, а не самого значения.
- ПОИСКПОЗ не зависит от регистра , что означает, что она не различает строчные и прописные символы при работе с текстовыми значениями.
- Если массив поиска содержит несколько вхождений искомого значения, возвращается позиция первого значения.
- Если искомое значение не найдено в просматриваемом массиве, возвращается ошибка #Н/Д.
Примеры
Формула =ПОИСК(«к»;»Первый канал») вернет 8, т.к. буква к находится на 8-й позиции слева.
Пусть в ячейке А2 введена строка Первый канал — лучший . Формула =ПОИСК(СИМВОЛ(32);A2) вернет 7, т.к. символ пробела (код 32) находится на 7-й позиции.
Формула =ПОИСК(«#. #»;»Артикул #123# ID») будет искать в строке » Артикул #123# ID » последовательность из 5 символов, которая начинается и заканчивается на знак #.
Чтобы найти позицию второго вхождения буквы «а» в строке «мама мыла раму» используйте формулу =ПОИСК(«а»;»мама мыла раму»;ПОИСК(«а»;»мама мыла раму»)+1). Чтобы определить есть ли третье вхождение буквы «м» в строке «мама мыла раму» используйте формулу =ЕСЛИ(ДЛСТР(ПОДСТАВИТЬ(«мама мыла раму»;»м»;»»;3))=ДЛСТР(«мама мыла раму»);»Нет третьего вхождения м»;»Есть третье вхождение м»)
Формула =ПОИСК(«клад?»;»докладная») вернет 3, т.е. в слове «докладная» содержится слово из 5 букв, первые 4 из которых клад (начиная с третьей буквы слова докладная ).
Функция ИНДЕКС для массивов
Допустим, у нас есть таблица с наименованиями товаров, их ценой, количеством и итоговой суммой.
Наша задача – в заранее выбранной ячейке отобразить наименование 5-ой позиции в списке.
- Встаем в ячейку, куда планируем вывести требуемые данные. Затем жмем кнопку “Вставить функцию” (fx).
- В открывшемся окне вставки функции выбираем категорию “Ссылки и массивы” (или “Полный алфавитный перечень”), отмечаем строку “ИНДЕКС” и жмем OK.
- Далее программа предложит на выбор один из двух наборов аргументов, о которых мы писали выше (для массива или для ссылок). В рамках поставленной задачи выбираем первый вариант и жмем OK.
- Теперь нам нужно заполнить аргументы функции:
- В выбранной ячейке отобразится результат согласно заданным условиям отбора в аргументах функции. В нашем случае – это содержимое ячейки, находящейся в 1-ом столбце и 5-ой строке выделенного массива.
Как мы ранее отмечали, один из аргументов функции (“Номер_столбца” или “Номер_строки”) может оставаться незаполненным, если выделенный массив будет одномерным, т.е. занимать либо одну строку, либо один столбец. На практике это выглядит следующим образом.
- В окне аргументов функции в поле “Массив” выделяем только ячейки первого столбца. Указываем номер строки – 5, а номер столбца, соответственно, остается незаполненным, так как в выделенном нами массиве он только один.
- Нажав кнопку OK мы получим тот же результат в ячейке таблицы, хотя аргументы функции и ее формула будут отличаться от первоначального варианта.
Поиск позиций ВСЕХ текстовых значений, удовлетворяющих критерию
Функция ПОИСКПОЗ() возвращает только одно значение. Если в списке присутствует несколько значений, удовлетворяющих критерию, то эта функция не поможет.
Рассмотрим список с повторяющимися значениями в диапазоне B66:B72 . Найдем все позиции значения Груши .
Значение Груши находятся в позициях 2 и 5 списка. С помощью формулы массива
=(«груши»=$B$66:$B$72)*(СТРОКА($B$66:$B$72)-СТРОКА($D$65))
можно найти все эти позиции. Для этого необходимо выделить несколько ячеек (расположенных вертикально), в Строке формул ввести вышеуказанную формулу и нажать CTRL+SHIFT+ENTER . В позициях, в которых есть значение Груши будет выведено соответствующее значение позиции, в остальных ячейках быдет выведен 0.
C помощью другой формулы массива
=НАИБОЛЬШИЙ((«груши»=$B$66:$B$72)*(СТРОКА($B$66:$B$72)-СТРОКА($D$65));СТРОКА()-СТРОКА($D$65))
можно отсортировать найденные позиции, чтобы номера найденных позиций отображались в первых ячейках (см. файл примера ).
Поиск позиции в массивах с текстовыми значениями
Произведем поиск позиции в НЕ сортированном списке текстовых значений (диапазон B7:B13 )
Столбец Позиция приведен для наглядности и не влияет на вычисления.
Формула для поиска позиции значения Груши: =ПОИСКПОЗ(«груши»;B7:B13;0)
Формула находит первое значение сверху и выводит его позицию в диапазоне, второе значение Груши учтено не будет.
Чтобы найти номер строки, а не позиции в искомом диапазоне, можно записать следующую формулу: =ПОИСКПОЗ(«груши»;B7:B13;0)+СТРОКА($B$6)
Если искомое значение не обнаружено в списке, то будет возвращено значение ошибки #Н/Д. Например, формула =ПОИСКПОЗ(«грейпфрут»;B7:B13;0) вернет ошибку, т.к. значения «грейпфрут» в диапазоне ячеек B7:B13 нет.
В файле примера можно найти применение функции при поиске в горизонтальном массиве.
Поиск значений с помощью функций ВПР, ИНДЕКС и ПОИСКПОЗ
искомое слово. Думаю, результат. нужно из нескольких двумя столбцами как как вспомогательную в указанном диапазоне.Формула ищет в C2:C10(ПОИСКПОЗ) использована для
=ПОИСКПОЗ(D5;{«Jan»;»Feb»;»Mar»};0)(ИНДЕКС), чтобы найти
численность населения Воронежа
=ВПР
-
41находит первое значение,возвращает значение 2, поскольку ошибку. С помощью не соответствуют искомому что анимация, расположеннаяВведите в строке формул сделать один!
-
с одним мы комбинациях с другимиДополнительные сведения см. в первое значение, соответствующее
того, чтобы найтиВы можете преобразовать оценки ближайшее значение. в четвертом столбце(2345678;A1:E7;5)Формула равное аргументу
-
элемент 25 является вторым функции ЕОШИБКА мы выражению, и номер выше, полностью показывает в нее следующую
Добавим рядом с нашей использовали в ее функциями такими как: разделе, посвященном функции значению из нескольких угаданных учащихся в буквеннуюФункция (столбец D). Использованная. Формула возвращает ценуОписаниеискомое_значение в диапазоне. проверяем выдала ли столбца, в котором задачу. формулу: таблицей еще один аргументах оператор &.
ИНДЕКС, ВПР, ГПР ГПР.Капуста чисел ближайшее к систему, используя функциюMATCH формула показана в на другую деталь,Результат.Совет: функция ПОИСКПОЗ ошибку. соответствующее значение былоНажмите в конце не столбец, где склеим Учитывая этот оператор и др. НоК началу страницы(B7), и возвращает правильному.MATCH
(ПОИСКПОЗ) имеет следующий ячейке A14. потому что функция=ПОИСКПОЗ(39;B2:B5,1;0)Просматриваемый_массив Функцией Если да, то найдено.Пример 1. Первая идя Enter, а сочетание название товара и первый аргументом для какую пользу можетДля выполнения этой задачи значение в ячейкеФункция(ПОИСКПОЗ) так же, синтаксис:
Краткий справочник: обзор функции ВПР нашла ближайшееТак как точного соответствияможет быть неПОИСКПОЗ мы получаем значениеСУММ(($A$2:$D$9=F2)*СТОЛБЕЦ($A$2:$D$9)) для решения задачCtrl+Shift+Enter месяц в единое функции теперь является приносить данная функция используется функция ГПР.
C7 (ABS как Вы делалиMATCH(lookup_value,lookup_array,[match_type])
Использование функции ГПР
ВПР число, меньшее или нет, возвращается позиция упорядочен.следует пользоваться вместо ИСТИНА. Быстро меняемНаконец, все значения из типа – это
Одновременное использование функций ИНДЕКС и ПОИСКПОЗ
, чтобы ввести формулу целое с помощью значение FordМаркетинговый. По работая самостоятельно. ИзВажно:100возвращает модуль разницы это сПОИСКПОЗ(искомое_значение;просматриваемый_массив;[тип_сопоставления])Функции ссылки и поиска равное указанному (2345678). ближайшего меньшего элемента-1 одной из функций её на ЛОЖЬ нашей таблицы суммируются
при помощи какого-то не как обычную, оператора сцепки (&), этой причине первый самого названия функции Значения в первой). между каждым угаданнымVLOOKUPlookup_value (справка) Эта ошибка может (38) в диапазонеФункцияПРОСМОТР и умножаем на (в нашем примере вида цикла поочерёдно а как формулу чтобы получить уникальный Ford из отдела ПОИСКПОЗ понятно, что
Еще о функциях поиска
-
строке должны бытьДополнительные сведения см. в
-
и правильным числами.(ВПР). В этом
-
(искомое_значение) – можетИспользование аргумента массива таблицы
привести к неправильному
support.office.com
Функция ИНДЕКС в Excel
Функция ИНДЕКС возвращает содержимое ячейки, которая находится на пересечении заданных строки и столбца. Например, на рисунке ниже формула возвращает значение из диапазона A1:C4, которое находится на пересечении 3 строки и 2 столбца.
Стоит отметить, что номера строк и столбцов задаются относительно верхней левой ячейки диапазона. Например, если ту же таблицу расположить в другом диапазоне, то формула вернет тот же результат:
Если массив содержит только одну строку или один столбец, т.е. является вектором, то второй аргумент функции ИНДЕКС указывает номер значения в этом векторе. При этом третий аргумент указывать необязательно.
Например, следующая формула возвращает пятое значение из диапазона A1:A12 (вертикальный вектор):
Данная формула возвращает третье значение из диапазона A1:L1(горизонтальный вектор):
Правильное написание
Формула включает в себя следующие элементы:
- ПОИСКПОЗ() – указание самой функции;
- Искомое значение, позицию которого необходимо узнать. Можно указывать ссылки на ячейки или вписывать само значение.
- Диапазон данных – массив (таблица, строка, столбец) данных, среди которых будет осуществляться поиск;
- Тип сопоставления – уточнение того, какое значение предстоит искать (равное указанному в формуле, меньшее или большее).
Итак, финальный вариант формулы выглядит следующим образом:
[kod]ПОИСКПОЗ(искомое_значение;диапазон_данных;[тип_сопоставления]).[/kod]
Если вам необходимо одиночное использование функции, то она должна иметь строго указанный вид. В противном случае вы можете получить неверный результат или ошибку Н/Д.
Пример использования функции ПОИСКПОЗ
Предположим у нас есть список продуктов и нам нужно найти порядковый номер конкретного продукта в этом списке. В качестве искомого значения выбираем ячейку C3 («Апельсины») и задаем просматриваемый массив в виде диапазона ячеек A2:A13 (название продукта), тип сопоставления указываем 0:
Пример использования функции ПОИСКПОЗ
Теги
Функции ИНДЕКС и ПОИСКПОЗ в Excel – лучшая альтернатива для ВПР
Смотрите также B3, поскольку третья «Работа с данными» последовательных чисел;искомое_значениеINDIRECT(ref_text,[a1]) в основную таблицу, столбца. диапазона.=ВПР(B1;$A$7:$D$18;4;ЛОЖЬ). они возвращают, формула, затем находит ближайшееФормула не будет работать,=ВПР(«Japan»;$B$2:$D$2;3) число или текст,Этот учебник рассказывает о
Чтобы функция ПОИСКПОЗ работала строка является второй и выбрать инструментФункция ИНДЕКС() возвращает текстовые.ДВССЫЛ(ссылка_на_текст;[a1]) необходимо выполнить действие,Итак, давайте обратимся кЭта формула находит толькоГде ячейкаСинтаксис функции станет легкой и к нему и если значение вВ данном случае – который Вы ищите. главных преимуществах функций
с таблицей с по счету относительно «Проверка данных»: значения из ИсходногоПросматриваемый_массивПервый аргумент может быть известное как двойной нашей таблице и второе совпадающее значение.B1ЕСЛИОШИБКА понятной: возвращает значение из ячейке смысла нет! Цель Аргумент может бытьИНДЕКС двумя столбцами как ячейки A2, аВ открывшемся диалоговом окне списка, из строк,может быть не ссылкой на ячейку
- ВПР запишем формулу с
- Если же Вамсодержит объединенное значение
- очень прост:=INDEX($A$1:$E$11,4,5))
- столбцаA2
- этого примера – значением, в том
- и с одним мы
- столбец B:B является необходимо выбрать «Тип
- номера которых были
- упорядочен. (стиль A1 или
Базовая информация об ИНДЕКС и ПОИСКПОЗ
или вложенный функцией необходимо извлечь остальные аргументаIFERROR(value,value_if_error)=ИНДЕКС($A$1:$E$11;4;5))Cдлиннее 255 символов. исключительно демонстрационная, чтобы числе логическим, илиПОИСКПОЗ
использовали в ее вторым относительно столбца данных:» — «Список» получены на предыдущем-1 R1C1), именем диапазонаВПРВПР повторения, воспользуйтесь предыдущимlookup_valueЕСЛИОШИБКА(значение;значение_если_ошибка)Эта формула возвращает значение
ИНДЕКС – синтаксис и применение функции
той же строки: Вместо неё Вам Вы могли понять, ссылкой на ячейку.в Excel, которые аргументах оператор &. A:A. и указать в
шаге.
Функция
или текстовой строкой..
- , которая найдет информацию решением.(искомое_значение), аГде аргумент на пересечении
- =INDEX($C$2:$C$10,MATCH(AVERAGE($D$2:D$10),$D$2:D$10,1)) нужно использовать аналогичную как функцииlookup_array делают их более Учитывая этот операторПри необходимости можно получить поле «Источник» диапазонВ предельном случае м.б.ПОИСКПОЗ
- Второй аргумент определяет,Запишите функцию о стоимости проданныхЕсли Вам нужен список4value4-ой=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(СРЗНАЧ($D$2:D$10);$D$2:D$10;1)) формулуПОИСКПОЗ
(просматриваемый_массив) – диапазон привлекательными по сравнению первый аргументом для целую строку или ячеек: найдено столько женаходит наименьшее значение,
какого стиля ссылкаВПР в марте лимонов.
всех совпадений –
– аргумент
(значение) – этостроки иРезультат: MoscowИНДЕКСи ячеек, в котором с функции теперь является целый столбец, указавПереходим в ячейку A13 значений, сколько содержится которое больше или
содержится в первом, которая находит имяСуществует несколько способов выполнить функцияcol_index_num значение, проверяемое на5-гоИспользуя функцию/
ПОИСКПОЗ – синтаксис и применение функции
ИНДЕКС происходит поиск.ВПР значение FordМаркетинговый. По в качестве номера и выполняем аналогичные в исходном списке равно значению аргумента
аргументе: товара в таблице двумерный поиск. ПознакомьтесьВПР(номер_столбца), т.е. номер предмет наличия ошибкистолбца в диапазонеСРЗНАЧПОИСКПОЗработают в паре.
match_type
. Вы увидите несколько
этой причине первый строки и столбца действия только лишь (когда все значения
искомое_значение
A1
- Lookup table 1 с возможными вариантамитут не помощник, столбца, содержащего данные, (в нашем случаеA1:E11в комбинации с:
- Последующие примеры покажут(тип_сопоставления) – этот примеров формул, которые Ford из отдела
- соответственно значение 0 указываем другую ссылку удовлетворяют критерию). Поэтому., если аргумент равен, используя и выберите наиболее
- поскольку она возвращает которые необходимо извлечь. – результат формулы, то есть значениеИНДЕКС=INDEX(D5:D10,MATCH(TRUE,INDEX(B5:B10=A2,0),0)) Вам истинную мощь аргумент сообщает функции помогут Вам легко продаж не учитывается,
- (нуль). Для вывода на диапазон в формулу массива нужно распространятьПросматриваемый_массивTRUESKU подходящий. только одно значениеЕсли Вам необходимо обновитьИНДЕКС ячейкии=ИНДЕКС(D5:D10;ПОИСКПОЗ(ИСТИНА;ИНДЕКС(B5:B10=A2;0);0)) связки
- ПОИСКПОЗ справиться со многими ведь теперь для полученных строки или поле «Источник:» на диапазон тойдолжен быть упорядочен(ИСТИНА) или не, как искомое значение:
Вы можете использовать связку за раз – основную таблицу (Main/E4ПОИСКПОЗ4. Более высокая скоростьИНДЕКС
, хотите ли Вы сложными задачами, перед функции два форда столбца функцию ИНДЕКСТакой же выпадающий список же размерности, что по убыванию: ИСТИНА, указан;=VLOOKUP(A2,New_SKU,2,FALSE) из функций и точка. Но table), добавив данныеПОИСКПОЗ. Просто? Да!, в качестве третьего работы.и найти точное или которыми функция – это разные необходимо использовать в следует создать и и исходный список. ЛОЖЬ, Z-A, …,
Как использовать ИНДЕКС и ПОИСКПОЗ в Excel
R1C1=ВПР(A2;New_SKU;2;ЛОЖЬ)ВПР в Excel есть из второй таблицы); а аргументВ учебнике по аргумента функцииЕсли Вы работаетеПОИСКПОЗ приблизительное совпадение:ВПР значения (FordПродажи и качестве формулы массива. для ячейки A15. Вышеуказанная формула массива 2, 1, 0,, еслиЗдесь(VLOOKUP) и
функция (Lookup table), котораяvalue_if_errorВПРПОИСКПОЗ с небольшими таблицами,
, которая легко справляется1бессильна.
FordМаркетинговый). Просматриваемый диапазонФункция ПОИСКПОЗ используется дляДля подсчета общего количества
будет возвращать несколько -1, -2, …FNew_SKUПОИСКПОЗ
INDEX находится на другом(значение_если_ошибка) – этомы показывали пример
чаще всего нужно
то разница в
с многими сложнымиилиВ нескольких недавних статьях
- теперь распространяется на поиска указанного в очков в ячейке значений, поэтому перед и т. д.ALSE– именованный диапазон(MATCH), чтобы найти(ИНДЕКС), которая с листе или в значение, которое нужно формулы с функцией будет указывать
- быстродействии Excel будет, ситуациями, когдане указан мы приложили все 2 столбца, так качестве первого аргумента B11 используем формулу: вводом формулы нужноФункция(ЛОЖЬ).$A:$B
значение на пересечении
легкостью справится с
другой рабочей книге возвратить, если формулаВПР1 скорее всего, неВПР– находит максимальное усилия, чтобы разъяснить же благодаря оператору значения в диапазонеДля получения корректного результата выделить сразу весьПОИСКПОЗВ нашем случае ссылка
в таблице полей
этой задачей. Как Excel, то Вы выдаст ошибку.для поиска поили заметная, особенно воказывается в тупике. значение, меньшее или начинающим пользователям основы &, который мы ячеек или константе выражение должно быть диапазон, т.е. ячейки
возвращает не само имеет стильLookup table 1Название продукта будет выглядеть такая можете собрать искомоеНапример, Вы можете вставить нескольким критериям. Однако,-1 последних версиях. ЕслиРешая, какую формулу использовать равное искомому. Просматриваемый
функции
применяем во втором
массива. Она возвращает выполнено как формулаС10:С19 значение, а егоA1, а(строка) и формула, Вы узнаете значение непосредственно в формулу из предыдущего существенным ограничением такогов случае, если же Вы работаете для вертикального поиска, массив должен бытьВПР аргументе для склейки относительную позицию найденного массива. Функция СУММ, ввести формулу в позицию в аргументе
Почему ИНДЕКС/ПОИСКПОЗ лучше, чем ВПР?
, поэтому можно не2Месяц в следующем примере. формуле, которую вставляете примера в функцию решения была необходимость Вы не уверены, с большими таблицами, большинство гуру Excel упорядочен по возрастанию,и показать примеры значений из двух элемента или код получает массив ячеек Строке формул ипросматриваемый_массив указывать второй аргумент– это столбец(столбец) рассматриваемого массива:Как упоминалось выше, в основную таблицу.ЕСЛИОШИБКА добавлять вспомогательный столбец. что просматриваемый диапазон которые содержат тысячи считают, что то есть от более сложных формул
смежных диапазонов. Таким ошибки #Н/Д, если в виде столбца нажать. Например, функция и сосредоточиться на B, который содержит=VLOOKUP(«Lemons»,$A$2:$I$9,MATCH(«Mar»,$A$1:$I$1,0),FALSE)ВПРКак и в предыдущемвот таким образом: Хорошая новость: формула содержит значение, равное строк и сотни
4 главных преимущества использования ПОИСКПОЗ/ИНДЕКС в Excel:
ИНДЕКС меньшего к большему. для продвинутых пользователей. образом, значения берутся искомые данные отсутствуют. таблицы, номер которогоCRTL+SHIFT+ENTERПОИСКПОЗ(«б»;{«а»;»б»;»в»};0) первом. названия товаров (смотрите=ВПР(«Lemons»;$A$2:$I$9;ПОИСКПОЗ(«Mar»;$A$1:$I$1;0);ЛОЖЬ)не может извлечь примере, Вам понадобится=IFERROR(INDEX($A$1:$E$11,MATCH($G$2,$B$1:$B$11,0),MATCH($G$3,$A$1:$E$1,0)),ИНДЕКС среднему. Если же формул поиска, Excel/0 Теперь мы попытаемся, одновременно из двух При поиске числовых был определен функцией.
возвращает 2 — относительнуюИтак, давайте вернемся к на рисунке выше)Формула выше – это все повторяющиеся значения в таблице поиска»Совпадений не найдено./ Вы уверены, что будет работать значительноПОИСКПОЗ– находит первое если не отговорить столбцов Автомобиль и значений можно использовать ПОИСКПОЗ по критериюДля скрытия ошибок #ССЫЛКА!, позицию буквы «б» нашим отчетам поЗапишите формулу для вставки обычная функция
из просматриваемого диапазона. (Lookup table) вспомогательный Попробуйте еще раз!»)ПОИСКПОЗ такое значение есть, быстрее, при использованиинамного лучше, чем значение, равное искомому. Вас от использования Отдел. нежесткие критерии: ближайшее поиска «Очки» (наименование возвращаемой формулой массива, в массиве {«а»;»б»;»в»}.
продажам. Если Вы
цен из таблицы
ВПР Чтобы сделать это, столбец с объединенными=ЕСЛИОШИБКА(ИНДЕКС($A$1:$E$11;ПОИСКПОЗ($G$2;$B$1:$B$11;0);ПОИСКПОЗ($G$3;$A$1:$E$1;0));может искать по – ставьтеПОИСКПОЗВПР Для комбинацииВПРЧитайте также: Функции ИНДЕКС наибольшее или ближайшее столбца). Поскольку в к диапазону
Функция помните, то каждыйLookup table 2, которая ищет точное Вам потребуется чуть значениями. Этот столбец»Совпадений не найдено. значениям в двух0и. Однако, многие пользователиИНДЕКС, то хотя бы и ПОИСКПОЗ в наименьшее числа заданному. качестве аргумента номер_строкиС10:С19ПОИСКПОЗ отчёт – этона основе известных совпадение значения «Lemons» более сложная формула, должен быть крайним
Попробуйте еще раз!») столбцах, без необходимостидля поиска точногоИНДЕКС Excel по-прежнему прибегают/ показать альтернативные способы Excel и примерыПоскольку ПОИСКПОЗ возвращает относительную функции ИНДЕКС былоприменено правило Условногоне различает регистры отдельная таблица, расположенная названий товаров. Для в ячейках от составленная из нескольких левым в заданномИ теперь, если кто-нибудь создания вспомогательного столбца!
совпадения.вместо к использованиюПОИСКПОЗ реализации вертикального поиска их использования позицию элемента в передано значение 0, форматирования. при сопоставлении текста. на отдельном листе. этого вставьте созданную
A2 до A9.
функций Excel, таких
для поиска диапазоне. введет ошибочное значение,Предположим, у нас естьЕсли указываетеВПРВПРвсегда нужно точное в Excel.Nesa диапазоне, то есть, будет возвращен весьВ этом случае будут
Если функция
Чтобы формула работала
ранее формулу в Но так как какИтак, формула с формула выдаст вот список заказов, и1. В целом, такая, т.к. эта функция совпадение, поэтому третийЗачем нам это? –: Добрый день номер строки или столбец. выведены все значения,ПОИСКПОЗ верно, Вы должны качестве искомого значения Вы не знаете,INDEXВПР такой результат: мы хотим найти, значения в столбце замена увеличивает скорость гораздо проще. Так
аргумент функции спросите Вы. Да,Подскажите, пожалуйста, есть столбца, эта функцияРезультат расчетов: которые совпадают сне находит соответствующего дать названия своим для новой функции в каком именно(ИНДЕКС),может быть такой:Если Вы предпочитаете в сумму по двум поиска должны быть работы Excel на происходит, потому чтоПОИСКПОЗ потому что ли возможность поиска
может быть использованаКоличество сыгранных игр для критерием (без учета значения, возвращается значение таблицам (или диапазонам),ВПР столбце находятся продажиSMALL=VLOOKUP(B2&» «&C2,Orders!$A&$2:$D$2,4,FALSE)
ИНДЕКС и ПОИСКПОЗ – примеры формул
случае ошибки оставить критериям – упорядочены по возрастанию,13% очень немногие людидолжен быть равенВПР значений и их как один или каждой команды может РЕгиСТра). Критерий вводится
Как выполнить поиск с левой стороны, используя ПОИСКПОЗ и ИНДЕКС
ошибки #Н/Д. причем все названия: за март, то(НАИМЕНЬШИЙ) и=ВПР(B2&» «&C2;Orders!$A&$2:$D$2;4;ЛОЖЬ) ячейку пустой, тоимя покупателя а формула вернёт. до конца понимают0
– это не суммирование по всем сразу два аргумента быть рассчитано как в ячейкуЕсли должны иметь общую=VLOOKUP(VLOOKUP(A2,New_SKU,2,FALSE),Price,3,FALSE) не сможете задатьROWЗдесь в столбцах B можете использовать кавычки(Customer) и максимальное значение, меньшееВлияние все преимущества перехода. единственная функция поиска листам книги? функции: сумма выигранных, сыгранныхE6
тип_сопоставления часть. Например, так:=ВПР(ВПР(A2;New_SKU;2;ЛОЖЬ);Price;3;ЛОЖЬ) номер столбца для
(СТРОКА)
и C содержатся
(«»), как значениепродукт или равное среднему.ВПР
- с-1 в Excel, иПри условии, что:=ИНДЕКС(диапазон; ПОИСКПОЗ(аргументы); ПОИСКПОЗ(аргументы))
вничью и проигранных
.
- равен 0 иCA_SalesЗдесь третьего аргумента функцииНапример, формула, представленная ниже, имена клиентов и второго аргумента функции(Product). Дело усложняетсяЕсли указываете
- на производительность ExcelВПР
– находит наименьшее
её многочисленные ограничения
- искомые значенияТакая формула используется чаще игр. Используем следующуюДля создания списка, содержащегоискомое_значение,PriceВПР находит все повторения названия продуктов соответственно,ЕСЛИОШИБКА
Вычисления при помощи ИНДЕКС и ПОИСКПОЗ в Excel (СРЗНАЧ, МАКС, МИН)
тем, что один-1 особенно заметно, еслина связку значение, большее или могут помешать Вам есть НЕ на всего для поиска формулу: найденные значения, воспользуемсяявляется текстом, тоFL_Sales
– именованный диапазон. Вместо этого используется значения из ячейки а ссылка. Вот так: покупатель может купить, значения в столбце рабочая книга содержитИНДЕКС
равное искомому значению.
получить желаемый результат
каждом листе
сразу по двумДанная формула аналогична предыдущей формулой массива:искомое_значение,$A:$C функция F2 в диапазонеOrders!$A&$2:$D$2
IFERROR(INDEX(массив,MATCH(искомое_значение,просматриваемый_массив,0),"")
сразу несколько разных
поиска должны быть
сотни сложных формули Просматриваемый массив должен во многих ситуациях.- диапазон поиска критериям. и также должна=ИНДЕКС(Список; НАИМЕНЬШИЙ(может содержать подстановочныеTX_Salesв таблице
ПОИСКПОЗ
B2:B16 и возвращает
определяет таблицу для
О чём нужно помнить, используя функцию СРЗНАЧ вместе с ИНДЕКС и ПОИСКПОЗ
ЕСЛИОШИБКА(ИНДЕКС(массив;ПОИСКПОЗ(искомое_значение;просматриваемый_массив;0);»») продуктов, и имена упорядочены по убыванию, массива, таких какПОИСКПОЗ быть упорядочен по С другой стороны, и столбец соAlexKoul использоваться в качествеЕСЛИ($E$6=Список;СТРОКА(Список)-СТРОКА($A$9);30); знаки: звездочку (и так далее.Lookup table 2, чтобы определить этот результат из тех поиска на другомНадеюсь, что хотя бы покупателей в таблице а возвращено будетВПР+СУММ, а тратить время убыванию, то есть функции значениями на каждом
- : Уважаемые форумчане! формулы массива. БлагодаряСТРОКА(ДВССЫЛ(«A1:A»&ЧСТРОК(Список)))))* Как видите, во, а столбец. же строк в
- листе. одна формула, описанная на листе минимальное значение, большее. Дело в том, на изучение более от большего кИНДЕКС
листе одинаковВозникла такая задача: списку, привязанному кВ этом случае будут) и вопросительный знак всех именах присутствует3MATCH(«Mar»,$A$1:$I$1,0) столбце C.Чтобы сделать формулу более в этом учебнике,Lookup table или равное среднему. что проверка каждого сложной формулы никто меньшему.и- условие поиска
Как при помощи ИНДЕКС и ПОИСКПОЗ выполнять поиск по известным строке и столбцу
имеется список марок ячейке A13, можно выведены все значения, ( «_Sales».– это столбецПОИСКПОЗ(«Mar»;$A$1:$I$1;0)
{=IFERROR(INDEX($C$2:$C$16,SMALL(IF($F$2=B2:B16,ROW(C2:C16)-1,»»),ROW()-3)),»»)} читаемой, Вы можете показалась Вам полезной.расположены в произвольномВ нашем примере значения значения в массиве не хочет.На первый взгляд, пользаПОИСКПОЗ в списке на
с соответствующими значениями легко определить число которые начинаются или?Функция
C, содержащий цены.
В переводе на человеческий
{=ЕСЛИОШИБКА(ИНДЕКС($C$2:$C$16;НАИМЕНЬШИЙ(ЕСЛИ($F$2=B2:B16;СТРОКА(C2:C16)-1;»»);СТРОКА()-3));»»)} задать имя для Если Вы сталкивались
порядке. в столбце требует отдельного вызоваДалее я попробую изложить от функции– более гибкие одном листе не (в примере выделено сыгранных игр для совпадают с критерием.). Звездочка соответствует любойДВССЫЛНа рисунке ниже виден язык, данная формула
Введите эту формулу массива просматриваемого диапазона, и с другими задачамиВот такая формулаD
функции главные преимущества использованияПОИСКПОЗ и имеют ряд повторяется
желтым). Нужно в любой команды: Критерий вводится в последовательности знаков, вопросительныйсоединяет значение в результат, возвращаемый созданной означает: в несколько смежных
тогда формула станет поиска, для которыхИНДЕКСупорядочены по возрастанию,ВПРПОИСКПОЗвызывает сомнение. Кому особенностей, которые делают
Пыталась ЕСЛИОШИБКА ВПР+ВПР, зеленую зону вывестиДля определения количества очков ячейку знак — любому одиночному столбце D и нами формулой:
Ищем символы «Mar» – ячеек, например, в выглядеть гораздо проще: не смогли найти/ поэтому мы используем. Поэтому, чем большеи
- нужно знать положение их более привлекательными, но получается слишком список марок, значение используем формулу ИНДЕКС,G6 знаку. Если нужно текстовую строку «_Sales»,В начале разъясним, что аргумент ячейки=VLOOKUP(B2&» «&C2,Orders,4,FALSE)
подходящее решение среди
ПОИСКПОЗ
тип сопоставления значений содержит массивИНДЕКС элемента в диапазоне? по сравнению с длинная формула – которых больше или
- в которой оба. найти сам вопросительный тем самым сообщая мы подразумеваем подlookup_valueF4:F8=ВПР(B2&» «&C2;Orders;4;ЛОЖЬ) информации в этомрешает задачу:
1
и чем больше
в Excel, а Мы хотим знатьВПР не влезает (листов
равно значению, вводимому аргумента, указывающие номерДля создания списка, содержащего знак или звездочку,
ВПР
выражением «Динамическая подстановка
(искомое_значение);, как показано наЧтобы формула работала, значения уроке, смело опишите{=INDEX(‘Lookup table’!$A$2:$C$13,MATCH(1,(A2=’Lookup table’!$A$2:$A$13)*. Формула
формул массива содержит
Вы решите –
значение этого элемента!. много) в ячейку С2. строки и столбца, найденные значения, воспользуемся перед ними следуетв какой таблице данных из разныхИщем в ячейках от рисунке ниже. Количество
Поиск по нескольким критериям с ИНДЕКС и ПОИСКПОЗ
в крайнем левом свою проблему в(B2=’Lookup table’!$B$2:$B$13),0),3)}ИНДЕКС Ваша таблица, тем остаться сПозвольте напомнить, что относительноеБазовая информация об ИНДЕКСAndreTMПрошу помочь с будут принимать значения, формулой массива: ввести знак тильды искать. Если в таблиц», чтобы убедиться A1 до I1 ячеек должно быть столбце просматриваемой таблицы
комментариях, и мы{=ИНДЕКС(‘Lookup table’!$A$2:$C$13;ПОИСКПОЗ(1;(A2=’Lookup table’!$A$2:$A$13)*/ медленнее работает Excel.ВПР положение искомого значения и ПОИСКПОЗ: В такой ситуации решением этой задачи. возвращаемые функцией ПОИСКПОЗ:=ИНДЕКС(Список;НАИМЕНЬШИЙ( ( ячейке D3 находится правильно ли мы – аргумент равным или большим, должны быть объединены все вместе постараемся
(B2=’Lookup table’!$B$2:$B$13);0);3)}ПОИСКПОС другой стороны, формулаили переключиться на (т.е. номер строки
Используем функции ИНДЕКС и
данные собирать проще
Заранее благодарю всех
Пример расчета:
ЕСЛИ(ЕСЛИОШИБКА(ПОИСК($G$6;Список);0)=1;СТРОКА(Список)-СТРОКА($A$9);30);~ значение «FL», формула понимает друг друга.lookup_array чем максимально возможное точно так же, решить её.Эта формула сложнее других,З с функциямиИНДЕКС и/или столбца) –
ПОИСКПОЗ в Excel
макросом, поскольку все
откликнувшихся!В результате мы получилиСТРОКА(ДВССЫЛ(«A1:A»&ЧСТРОК(Список)))))). выполнит поиск вБывают ситуации, когда есть(просматриваемый_массив); число повторений искомого как и вУрок подготовлен для Вас которые мы обсуждали
- возвращает «Moscow», посколькуПОИСКПОЗ/ это как разПреимущества ИНДЕКС и ПОИСКПОЗ равно действия два:китин значение по 2-мВ этом случае будутСкопируйте образец данных из таблице
- несколько листов сВозвращаем точное совпадение – значения. Не забудьте критерии поиска. На командой сайта office-guru.ru ранее, но вооруженные величина населения города
- иПОИСКПОЗ то, что мы перед ВПР сначала надо объединить
- : можно так критериям: выведены все значения, следующей таблицы иFL_Sales данными одного формата, аргумент нажать рисунке выше мыИсточник: https://www.ablebits.com/office-addins-blog/2014/08/13/excel-index-match-function-vlookup/ знанием функций Москва – ближайшееИНДЕКС. должны указать для
ИНДЕКС и ПОИСКПОЗ – данные из всех200?’200px’:»+(this.scrollHeight+5)+’px’);»>=ЕСЛИОШИБКА(ИНДЕКС($G$2:$G$7;НАИМЕНЬШИЙ(ЕСЛИ($C$2– «Челси». которые заканчиваются или вставьте их в, если «CA» – и необходимо извлечьmatch_type
Ctrl+Shift+Enter объединили значения иПеревел: Антон АндроновИНДЕКС меньшее к среднемупросто совершает поиск1. Поиск справа налево. аргументов примеры формул таблиц в одинформула массива– «Очки». совпадают с критерием. ячейку A1 нового в таблице нужную информацию с(тип_сопоставления)., чтобы правильно ввести поставили между нимиАвтор: Антон Андронов
и значению (12 269 и возвращает результат,Как известно любомуrow_numКак находить значения, которые список, а потомдля 2003 подлиньше Критерий вводится в листа Excel. ЧтобыCA_Sales определенного листа вИспользовав
формулу массива. пробел, точно такВо второй части нашегоПОИСКПОЗ
ИНДЕКС и ПОИСКПОЗ в сочетании с ЕСЛИОШИБКА в Excel
006). выполняя аналогичную работу грамотному пользователю Excel,(номер_строки) и/или находятся слева уже сгруппировать с будет Код200?’200px’:»+(this.scrollHeight+5)+’px’);»>=ЕСЛИ(ЕОШИБКА(ИНДЕКС($G$2:$G$7;НАИМЕНЬШИЙ(ЕСЛИ($C$2Пример 2. Используя таблицу ячейку отобразить результаты формул,и так далее. зависимости от значения,0Если Вам интересно понять, же необходимо сделать учебника по функцииВы одолеете ее.Эта формула эквивалентна двумерному заметно быстрее.ВПРcolumn_numВычисления при помощи ИНДЕКС агрегацией. Постов на_Boroda_ из предыдущего примера
I6 выделите их иРезультат работы функций
которое введено в
в третьем аргументе,
как она работает, в первом аргументеВПР Самая сложная часть поискуТеперь, когда Вы понимаетене может смотреть(номер_столбца) функции и ПОИСКПОЗ тему «собрать/объединить данные: Еще вариант определить суммарное количество. нажмите клавишу F2,ВПР заданную ячейку. Думаю,
Вы говорите функции давайте немного погрузимся функции (B2&» «&C2).(VLOOKUP) в Excel – это функция
ВПР
причины, из-за которых влево, а этоINDEX
Поиск по известным строке с нескольких листов"
200?’200px’:»+(this.scrollHeight+5)+’px’);»>=ЕСЛИОШИБКА(ПРОСМОТР(;-1/(H$2:H$7>=C$2)/ЕНД(ПОИСКПОЗ(G$2:G$7;C$3:C3;));G$2:G$7);»») заработанных очков несколькимиДля создания списка, содержащего а затем — клавишу
и проще это объяснитьПОИСКПОЗ в детали формулы:Запомните! мы разберём несколькоПОИСКПОЗи позволяет найти
стоит изучать функции
значит, что искомое
(ИНДЕКС). Как Вы и столбцу в поиске достаточно,ввод обычный, немассивный командами (задается опционально). найденные значения, воспользуемся ВВОД. При необходимостиДВССЫЛ на примере.искать первое значение,IF($F$2=B2:B16,ROW(C2:C16)-1,»»)Функция примеров, которые помогут, думаю, её нужно значение на пересечении
ПОИСКПОЗ значение должно обязательно
помните, функция
Поиск по нескольким критериям
а «группировка/агрегация» -
office-guru.ru
Продвинутые примеры с функцией ВПР: поиск по нескольким критериям
AlexKoulВид таблицы данных: формулой массива: измените ширину столбцов,будет следующий:Представьте, что имеются отчеты в точности совпадающееЕСЛИ($F$2=B2:B16;СТРОКА(C2:C16)-1;»»)ВПР Вам направить всю объяснить первой. определённой строки ии находиться в крайнемИНДЕКСИНДЕКС и ПОИСКПОЗ в это сводная таблица: Огромное спасибо!Искомое значение может быть=ИНДЕКС(Список;НАИМЕНЬШИЙ( чтобы видеть всеЕсли данные расположены в по продажам для с искомым значением.$F$2=B2:B16
- ограничена 255 символами, мощь
- MATCH(1,(A2=’Lookup table’!$A$2:$A$13),0)*(B2=’Lookup table’!$B$2:$B$13) столбца.ИНДЕКС
- левом столбце исследуемогоможет возвратить значение,
- сочетании с ЕСЛИОШИБКА по уже собранному
- AlexBer найдено с помощью
- ЕСЛИ($I$6=ПРАВСИМВ(Список;ДЛСТР($I$6));СТРОКА(Список)-СТРОКА($A$9);30); данные.
Поиск в Excel по нескольким критериям
разных книгах Excel, нескольких регионов с Это равносильно значению– сравниваем значение она не можетВПРПОИСКПОЗ(1;(A2=’Lookup table’!$A$2:$A$13);0)*(B2=’Lookup table’!$B$2:$B$13)В этом примере формула, давайте перейдём к диапазона. В случае находящееся на пересеченииТак как задача этого в одно место: Ребята, благодарю за следующей формулы:СТРОКА(ДВССЫЛ(«A1:A»&ЧСТРОК(Список)))))
Пример 1: Поиск по 2-м разным критериям
Продукт то необходимо добавить одинаковыми товарами иFALSE в ячейке F2 искать значение, состоящеена решение наиболееВ формуле, показанной выше,ИНДЕКС самому интересному и с заданных строки и учебника – показать источнику. Вашу поддержку,
Функция СУММ рассчитывает суммуСОВЕТ:Количество имя книги перед в одинаковом формате.(ЛОЖЬ) для четвёртого с каждым из из более чем амбициозных задач Excel. искомое значение –/ увидим, как можноПОИСКПОЗ столбца, но она возможности функций
Ну или если
По образу и
значений, хранящихся вО поиске текстовыхБананы именованным диапазоном, например: Требуется найти показатели аргумента значений диапазона B2:B16.
255 символов. Имейте Примеры подразумевают, что этоПОИСКПОЗ применить теоретические знания/ не может определить,ИНДЕКС с макросами сложно подобию составил свой столбце «Очки», при значений с использованием25=VLOOKUP($D$2,INDIRECT($D3&»Workbook1!_Sales»),2,FALSE) продаж для определенногоВПР Если найдено совпадение, это ввиду и Вы уже имеете
1будет очень похожа на практике.ИНДЕКС какие именно строкаи — то можно рабочий файл, очень этом количество ячеек подстановочных знаков читайтеАпельсины=ВПР($D$2;ДВССЫЛ($D3&»Workbook1!_Sales»);2;ЛОЖЬ) региона:
.
то выражение
следите, чтобы длина
базовые знания о
, а массив поиска
на формулы, которыеЛюбой учебник по, столбец поиска может и столбец насПОИСКПОЗ превратить все таблицы доволен результатом. для расчета может в статье Поиск38Если функцияЕсли у Вас всего
Пример 2: ВПР по двум критериям с просматриваемой таблицей на другом листе
Вот так Вы можетеСТРОКА(C2:C16)-1 искомого значения не том, как работает – это результат мы уже обсуждалиВПР быть, как в интересуют.для реализации вертикального данных в «умные»,Есть один нюанс, быть задано с
текстовых значений вЯблокиДВССЫЛ два таких отчета, создать формулу длявозвращает номер соответствующей превышала этот лимит. эта функция. Если умножения. Хорошо, что
в этом уроке,твердит, что эта левой, так и
Теперь, когда Вам известна
поиска в Excel,
а затем задействовать который хотелось бы помощью критерия – списках. Часть2. Подстановочные40ссылается на другую то можно использовать поиска по двум строки (значение
Соглашусь, добавление вспомогательного столбца нет, возможно, Вам же мы должны с одним лишь функция не может в правой части
базовая информация об
мы не будем
инструменты Power Query. доработать. выбранного названия команды. знаки. В статьеГруши книгу, то эта до безобразия простую критериям в Excel,-1 – не самое будет интересно начать перемножить и почему? отличием. Угадайте каким? смотреть влево. Т.е.
диапазона поиска. Пример: этих двух функциях, задерживаться на ихНасколько «много» уВ приложенном файле Функция ИНДЕКС может Выделение ячеек c41 книга должна быть формулу с функциями что также известно,позволяет не включать
изящное и не с первой части Давайте разберем всеКак Вы помните, синтаксис если просматриваемый столбец Как находить значения, полагаю, что уже синтаксисе и применении. вас листов с пример, с предложенной возвращать не только ТЕКСТом с применениемФормула открытой. Если жеВПР
Извлекаем 2-е, 3-е и т.д. значения, используя ВПР
как двумерный поиск строку заголовков). Если всегда приемлемое решение. этого учебника, в по порядку: функции не является крайним которые находятся слева становится понятно, какПриведём здесь необходимый минимум данными? формулой значение, хранящееся в Условного форматирования приведено решениеОписание она закрыта, функция
и или поиск в совпадений нет, функция Вы можете сделать которой объясняются синтаксисБерем первое значение вINDEX левым в диапазоне покажет эту возможность функции
для понимания сути,NesaВывод значений происходит искомой ячейке, но аналогичной задачи сРезультат сообщит об ошибкеЕСЛИ двух направлениях.IF то же самое и основное применение столбце(ИНДЕКС) позволяет использовать поиска, то нет в действии.ПОИСКПОЗ а затем разберём
: 24 листа, в
снизу вверх ,
и ссылку на использованием Условного форматирования.=ПОИСКПОЗ(39;B2:B5,1;0)#REF!(IF), чтобы выбрать
- Функция(ЕСЛИ) возвращает пустую без вспомогательного столбца,ВПРA
три аргумента:
шансов получить от
- 2. Безопасное добавление илии подробно примеры формул, принципе можно разбить а мне для
эту ячейку. Поэтому
Как использовать функцию
Так как точного соответствия(#ССЫЛ!). нужный отчет дляСУММПРОИЗВ строку. но в таком. Что ж, давайте
(Customer) на листеINDEX(array,row_num,[column_num])ВПР удаление столбцов.ИНДЕКС которые показывают преимущества
н 2 файла
удобства, да и
можно использовать запись
- ВПР (VLOOKUP) нет, возвращается позицияУрок подготовлен для Вас поиска:(SUMPRODUCT) возвращает сумму
- Результатом функции случае потребуется гораздо приступим.Main table
- ИНДЕКС(массив;номер_строки;[номер_столбца])желаемый результат.Формулы с функциеймогут работать вместе. использования
- по 12 листов из эстетических соображений типа E2:ИНДЕКС(…). Вдля поиска и
ближайшего меньшего элемента командой сайта office-guru.ru=VLOOKUP($D$2,IF($D3=»FL»,FL_Sales,CA_Sales),2,FALSE) произведений выбранных массивов:IF более сложная формула
Поиск в Excel пои сравниваем егоИ я поздравляю техФункцииВПРПОИСКПОЗИНДЕКСмакросом не то хотелось бы видеть результате выполнения функция выборки нужных значений (38) в диапазонеИсточник: https://www.ablebits.com/office-addins-blog/2014/07/29/vlookup-formula-examples/=ВПР($D$2;ЕСЛИ($D3=»FL»;FL_Sales;CA_Sales);2;ЛОЖЬ)=SUMPRODUCT(($A$2:$A$9=»Lemons»)*($A$1:$I$1=»Mar»),$A$2:$I$9)(ЕСЛИ) окажется вот с комбинацией функций нескольким критериям
Извлекаем все повторения искомого значения
со всеми именами из Вас, ктоПОИСКПОЗперестают работать илиопределяет относительную позициюи чтобы сложно, я список в том ИНДЕКС вернет ссылку из списка мы B2:B5.Перевел: Антон АндроновГде:=СУММПРОИЗВ(($A$2:$A$9=»Lemons»)*($A$1:$I$1=»Mar»);$A$2:$I$9) такой горизонтальный массив:INDEXИзвлекаем 2-е, 3-е и
покупателей в таблице догадался!и возвращают ошибочные значения, искомого значения вПОИСКПОЗ слова этого боюсь же порядке, в
на ячейку, и
недавно разбирали. Если
2Автор: Антон Андронов$D$2В следующей статье я{1,»»,3,»»,5,»»,»»,»»,»»,»»,»»,12,»»,»»,»»}(ИНДЕКС) и т.д. значения, используя на листеНачнём с того, чтоИНДЕКС если удалить или заданном диапазоне ячеек,вместоа умные таблицы каком и в приведенная выше запись
вы еще с=ПОИСКПОЗ(41;B2:B5;0)Функция– это ячейка,
Часть 1:
буду объяснять эти
ROW()-3
MATCH ВПРLookup table запишем шаблон формулы.в Excel гораздо добавить столбец в аВПР — это какие? исходной таблице. примет, например, следующий ней не знакомыПозиция значения 41 вПОИСКПОЗ содержащая название товара. функции во всехСТРОКА()-3
(ПОИСКПОЗ).Извлекаем все повторения искомого(A2:A13). Для этого возьмём более гибкие, и
Часть 2:
таблицу поиска. Для
ИНДЕКС
.AndreTMПодскажите пожалуйста если вид: E2:E4 (если — загляните сюда, диапазоне B2:B5выполняет поиск указанного Обратите внимание, здесь деталях, так чтоЗдесь функцияВы уже знаете, что значенияЕсли совпадение найдено, уравнение уже знакомую нам им все-равно, где функциииспользует это числоФункция: Если «боитесь» макросов это возможно сделать выбрана команда «Манчестер
Часть 3:
не пожалейте пяти
4
элемента в диапазоне мы используем абсолютные сейчас можете простоROWВПРДвумерный поиск по известным возвращает формулу находится столбец соВПР (или числа) иINDEX — изучайте Power улучшив уже используемую Ю.». минут, чтобы сэкономить=ПОИСКПОЗ(40;B2:B5;-1) ячеек и возвращает ссылки, чтобы избежать скопировать эту формулу:(СТРОКА) действует какможет возвратить только строке и столбцу1ИНДЕКС значением, которое нужнолюбой вставленный или возвращает результат из(ИНДЕКС) в Excel Query и Power
Часть 4:
формулу.
Пример расчетов:
себе потом несколькоВозвращает сообщение об ошибке, относительную позицию этого изменения искомого значения=INDEX($A$2:$I$9,MATCH(«Lemons»,$A$2:$A$9,0),MATCH(«Mar»,$A$1:$I$1,0)) дополнительный счётчик. Так одно совпадающее значение,Используем несколько ВПР в(ИСТИНА), а если/ извлечь. Для примера, удалённый столбец изменит соответствующей ячейки. возвращает значение из Pivot.С уважением,Проверим результат выборочного динамического часов. так как диапазон
Часть 5:
элемента в диапазоне.
при копировании формулы
=ИНДЕКС($A$2:$I$9;ПОИСКПОЗ(«Lemons»;$A$2:$A$9;0);ПОИСКПОЗ(«Mar»;$A$1:$I$1;0)) как формула скопирована точнее – первое одной формуле нет –ПОИСКПОЗ снова вернёмся к результат формулы, посколькуЕщё не совсем понятно? массива по заданнымНу и неАлександр. суммирования столбца таблицыЕсли же вы знакомы
Двумерный поиск по известным строке и столбцу
B2:B5 упорядочен не Например, если диапазон в другие ячейки.Если Вы не в в ячейки F4:F9, найденное. Но какДинамическая подстановка данных из0и добавим в
таблице со столицами синтаксис Представьте функции номерам строки и бойтесь спрашивать уСмотрите формулу выше с верху вниз. с ВПР, то
по убыванию. A1:A3 содержит значения$D3 восторге от всех мы вычитаем число
Функции ВПР и ПОИСКПОЗ
быть, если в разных таблиц(ЛОЖЬ). неё ещё одну государств и населением.ВПРИНДЕКС столбца. Функция имеет Гуглояндекса (пост №2).Сумма чисел в диапазоне — вдогон -
#Н/Д
5, 25 и
– это ячейка этих сложных формул3 просматриваемом массиве этоФункцияДалее, мы делаем то функцию На этот разтребует указывать весьи вот такой синтаксис:А «умные таблицы»Если возникнут вопросы, E2:E7 и в стоит разобраться сНайдем текстовые значения, удовлетворяющие 38, то формула с названием региона. Excel, Вам можетиз результата функции, значение повторяется несколько
ВПР
же самое для
ПОИСКПОЗ запишем формулу диапазон и конкретный
- ПОИСКПОЗINDEX(array,row_num,[column_num]) — это «форматировать создавайте свою тему,
- ячейке B13 совпадает похожими функциями: заданному пользователем критерию.=ПОИСКПОЗ(25;A1:A3;0) Используем абсолютную ссылку
- понравиться вот такой чтобы получить значение раз, и Выв Excel –
значений столбца, которая будет возвращатьПОИСКПОЗ номер столбца, изв таком виде:ИНДЕКС(массив;номер_строки;[номер_столбца]) как таблицу» и эта закрыта. все ОК.ИНДЕКС (INDEX) Поиск будем осуществлятьвозвращает значение 2, поскольку для столбца и наглядный и запоминающийся
1 хотите извлечь 2-е это действительно мощныйB номер столбца./ которого нужно извлечь=INDEX(столбец из которого извлекаем,(MATCH
Функция СУММПРОИЗВ
Каждый аргумент имеет очень затем изменить ейВо многих поисковых формулахПример 3. В таблице
и
в диапазоне с
Функции ИНДЕКС и ПОИСКПОЗ
элемент 25 является вторым относительную ссылку для способ:в ячейке или 3-е из инструмент для выполнения
(Product).
=INDEX(Ваша таблица,(MATCH(значение для вертикального
Именованные диапазоны и оператор пересечения
ИНДЕКС данные. (искомое значение,столбец в простое объяснение: имя, если надо. очень часто приходится табеля рабочего времени
- ПОИСКПОЗ (MATCH) повторяющимися значениями. При в диапазоне. строки, поскольку планируемВыделите таблицу, откройте вкладку
- F4 них? А что поиска определённого значенияЗатем перемножаем полученные результаты поиска,столбец, в котором, которая покажет, какоеНапример, если у Вас котором ищем,0))arrayА обработка с использовать функцию ПОИСКПОЗ хранятся данные о, владение которыми весьма наличии повторов, можноСовет:
- копировать формулу вFormulas(строка 4, вычитаем если все значения?
в базе данных.
(1 и 0).
искать,0)),(MATCH(значение для горизонтального место по населению есть таблица=ИНДЕКС(столбец из которого извлекаем;(ПОИСКПОЗ(искомое(массив) – это помощью Power Query как вспомогательную в
недавно принятых сотрудниках облегчит жизнь любому ожидать, что критерию Функцией другие ячейки того(Формулы) и нажмите
- 3), чтобы получить Задачка кажется замысловатой, Однако, есть существенное
Только если совпадения поиска,строка в которой занимает столица РоссииA1:C10 значение;столбец в котором диапазон ячеек, из
Используем несколько ВПР в одной формуле
— то примерно комбинациях с другими фирмы. Определить, сколько опытному пользователю Excel. будет соответствовать несколькоПОИСКПОЗ же столбца.Create from Selection2 но решение существует! ограничение – её найдены в обоих искать,0)) (Москва)., и требуется извлечь
ищем;0)) которого необходимо извлечь вот так: функциями такими как: рабочих дней на Гляньте на следующий значений. Для ихследует пользоваться вместоFL_Sal(Создать из выделенного).в ячейкеПредположим, в одном столбце синтаксис позволяет искать столбцах (т.е. оба=ИНДЕКС(Ваша таблица,(MATCH(значение для вертикальногоКак видно на рисунке данные из столбцаДумаю, ещё проще будет значение.gling ИНДЕКС, ВПР, ГПР текущий момент отработал
пример: вывода в отдельный одной из функцийesОтметьте галочкамиF5 таблицы записаны имена только одно значение. критерия истинны), Вы
- поиска,столбец, в котором ниже, формула отличноB понять на примере.row_num: Вариант формулами. и др. Но любой из новых
Необходимо определить регион поставки
диапазон удобно использовать
ПРОСМОТРиTop row(строка 5, вычитаем клиентов (Customer Name), Как же быть, получите искать,0)),(MATCH(значение для горизонтального справляется с этой, то нужно задать Предположим, у Вас(номер_строки) – это
- AndreTM какую пользу может недавно принятых сотрудников по артикулу товара, формулы массива., когда требуется найтиCA_Sales(в строке выше) 3) и так а в другом если требуется выполнить
1
поиска,строка в которой
задачей: значение есть вот такой номер строки в: Для «примера» - приносить данная функция фирмы. набранному в ячейкуПусть Исходный список значений позицию элемента в
– названия таблиц и далее.
Динамическая подстановка данных из разных таблиц при помощи ВПР и ДВССЫЛ
– товары (Product), поиск по нескольким. Если оба критерия искать,0))=INDEX($A$2:$A$10,MATCH(«Russia»,$B$2:$B$10,0))2 список столиц государств:
массиве, из которой формульного варианта, конечно, работая самостоятельно. ИзВид таблицы данных: C16. (например, перечень инструментов) диапазоне, а не (или именованных диапазонов),Left columnSMALL(IF($F$2=B2:B16,ROW(C2:C16)-1,»»),ROW()-3)) которые они купили.
условиям? Решение Вы ложны, или выполняетсяОбратите внимание, что для=ИНДЕКС($A$2:$A$10;ПОИСКПОЗ(«Russia»;$B$2:$B$10;0))для аргументаДавайте найдём население одной нужно извлечь значение. хватит.
самого названия функцииКак видно на рисункеЗадача решается при помощи находится в диапазоне сам элемент. Например, в которых содержаться(в столбце слева).НАИМЕНЬШИЙ(ЕСЛИ($F$2=B2:B16;СТРОКА(C2:C16)-1;»»);СТРОКА()-3)) Попробуем найти 2-й, найдёте далее. только один из
двумерного поиска нужно
Теперь у Вас не
col_index_num
- из столиц, например, Если не указан,Тем более, что ПОИСКПОЗ понятно, что в ячейке A10 двух функций:A10:A19 функцию соответствующие отчеты о
- Microsoft Excel назначитФункция 3-й и 4-йПредположим, у нас есть них – Вы указать всю таблицу должно возникать проблем(номер_столбца) функции Японии, используя следующую то обязательно требуется
- из него исключён ее главная задача снова используется выпадающий=ИНДЕКС(A1:G13;ПОИСКПОЗ(C16;D1:D13;0);2)(см. Файл примера).ПОИСКПОЗ продажах. Вы, конечно имена диапазонам изSMALL товары, купленные заданным список заказов и получите в аргументе с пониманием, какВПР формулу:
аргумент шаг по собиранию заключается в определении список, созданный поФункцияВыведем в отдельный диапазонможно использовать для же, можете использовать значений в верхней(НАИМЕНЬШИЙ) возвращает
клиентом. мы хотим найти0array работает эта формула:, вот так:=INDEX($D$2:$D$10,MATCH(«Japan»,$B$2:$B$10,0))column_num списка «искомых значений» позиции исходного значения, аналогичной схеме, описаннойПОИСКПОЗ значения, которые удовлетворяют передачи значения аргумента обычные названия листов строке и левомn-оеПростейший способ – добавитьКоличество товара.(массив) функцииВо-первых, задействуем функцию=VLOOKUP(«lookup value»,A1:C10,2)
=ИНДЕКС($D$2:$D$10;ПОИСКПОЗ("Japan";$B$2:$B$10;0))
(номер_столбца).
и «наименований листов».
- которое содержит диапазон выше.ищет в столбце критерию. Рассмотрим различныеномер_строки
- и ссылки на столбце Вашей таблицы.наименьшее значение в вспомогательный столбец перед(Qty.), основываясь наТеперь понимаете, почему мыINDEX
- MATCH=ВПР(«lookup value»;A1:C10;2)Теперь давайте разберем, чтоcolumn_num То есть при ячеек или таблица.Для определения искомого значенияD1:D13 варианты поиска.функции диапазоны ячеек, например Теперь Вы можете массиве данных. В столбцом двух критериях –
Как работают ДВССЫЛ и ВПР
задали(ИНДЕКС).(ПОИСКПОЗ), которая находитЕсли позднее Вы вставите
делает каждый элемент
(номер_столбца) – это
добавлении нового листа Применять эту функцию даты используем следующуюзначение артикула изДля удобства создадим именованныйИНДЕКС‘FL Sheet’!$A$3:$B$10 осуществлять поиск, используя нашем случае, какую
- Customer NameИмя клиента1А теперь давайте испытаем положение «Russia» в
- новый столбец между этой формулы: номер столбца в — надо делать очень просто для
формулу (формула массива ячейки диапазон Список.., но именованные диапазоны эти имена, напрямую, по счёту позицию
и заполнить его(Customer) и, как искомое значение? этот шаблон на списке: столбцамиФункция массиве, из которого не только телодвижения диапазонов или таблиц CTRL+SHIFT+ENTER):C16Диапазон может охватить вПОИСКПОЗ(искомое_значение;просматриваемый_массив;[тип_сопоставления]) гораздо удобнее. без создания формул. (от наименьшего) возвращать именами клиентов сНазвание продукта Правильно, чтобы функция практике. Ниже Вы=MATCH(«Russia»,$B$2:$B$10,0))A
MATCH нужно извлечь значение. по внесению его с одним столбцом»»;0))))’ class=’formula’>. Последний аргумент функции том числе иАргументы функции ПОИСКПОЗ описаныОднако, когда таких таблицВ любой пустой ячейке – определено функцией номером повторения каждого(Product). Дело усложняетсяПОИСКПОЗ видите список самых=ПОИСКПОЗ(«Russia»;$B$2:$B$10;0))и(ПОИСКПОЗ) ищет значение
Если не указан, имени в список или с однойПервая функция ИНДЕКС выполняет 0 — означает
незаполненные ячейки перечня. ниже. много, функция запишитеROW
имени, например,
тем, что каждый
возвращала позицию только, населённых стран мира.Далее, задаём диапазон дляB «Japan» в столбце то обязательно требуется — но и строкой. Поэтому сразу поиск ячейки с поиск точного (а
В дальнейшем пользовательИскомое_значение.
ЕСЛИ
=имя_строки имя_столбца
(СТРОКА) (смотри Часть
office-guru.ru
Функция ПОИСКПОЗ
John Doe1 из покупателей заказывал когда оба критерия Предположим, наша задача функции, то значение аргументаB аргумент быть уверенным, что усложним задачу и датой из диапазона не приблизительного) соответствия. может расширить перечень Обязательный аргумент. Значение, которое– это не
, например, так: 2). Так, для, несколько видов товаров, выполняются. узнать население СШАINDEX придется изменить с, а конкретно –row_num там не появилось на конкретном примере A1:I1. Номер строки Функция выдает порядковый инструментов, указанные ниже сопоставляется со значениями лучшее решение. Вместо=Lemons Mar
Синтаксис
ячейки
John Doe2 как это видно
-
Обратите внимание: в 2015 году.(ИНДЕКС), из которого2 в ячейках(номер_строки) нового «искомого значения», проиллюстрируем как применять указан как 1 номер найденного значения формулы автоматически учтут в аргументе
нее можно использовать… или наоборот:F4и т.д. Фокус из таблицы ниже:В этом случаеХорошо, давайте запишем формулу. -
нужно извлечь значение.наB2:B10Если указаны оба аргумента,
-
которое отсутствует в функцию ПОИСКПОЗ для для упрощения итоговой в диапазоне, т.е. новые значения.просматриваемый_массив функцию=Mar Lemonsфункция с нумерацией сделаемОбычная функция необходимо использовать третий Когда мне нужно В нашем случае
3, и возвращает число то функция общем списке (или таблицы с двумя формулы. Функция СТОЛБЕЦ фактически номер строки,
Выведем в отдельный диапазон |
. Например, при поиске |
ДВССЫЛ |
Помните, что имена строкиНАИМЕНЬШИЙ({массив};1) при помощи функцииВПР не обязательный аргумент создать сложную формулу это, иначе формула возвратит3ИНДЕКС выявить эти новые столбцами и более. возвращает номер столбца |
где найден требуемыый |
все значения Исходного номера в телефонной(INDIRECT), чтобы возвратить и столбца нужновозвращаетCOUNTIFне будет работать функции в Excel с |
A2:A10 |
результат из только, поскольку «Japan» ввозвращает значение из значения и добавитьДля примера возьмем список с ячейкой, в артикул. списка, в которых книге имя абонента нужный диапазон поиска. разделить пробелом, который1-й(СЧЁТЕСЛИ), учитывая, что по такому сценарию, |
-
ИНДЕКС вложенными функциями, то. что вставленного столбца. списке на третьем ячейки, находящейся на в общий). автомобилей из автопарка которой хранится перваяФункциясодержится
-
указывается в качествеКак Вы, вероятно, знаете, в данном случае(наименьший) элемент массива,
-
имена клиентов находятся поскольку она возвратит. Он необходим, т.к. я сначала каждуюЗатем соединяем обе части
-
Используя месте. пересечении указанных строкиТем более, что средней фирмы, как запись о часахИНДЕКСтекст-критерий (например, слово искомого значения, а функция работает как оператор то есть в столбце B: первое найденное значение, в первом аргументе вложенную записываю отдельно. и получаем формулу:ПОИСКПОЗФункция и столбца. Анна лукавит показано ниже на работы. Выражение «ИНДЕКС(B1:I6;ПОИСКПОЗ(A10;A1:A6;0);ПОИСКПОЗ(ИСТИНА;ИНДЕКС(B1:I6;ПОИСКПОЗ(A10;A1:A6;0);0)<>»»»
Пример
выбирает из диапазона дрель). Критерий вводится нужным значением будетДВССЫЛ пересечения.1=B2&COUNTIF($B$2:B2,B2) соответствующее заданному искомому мы задаем всюИтак, начнём с двух=INDEX($A$2:$A$10;MATCH(«Russia»;$B$2:$B$10;0))/INDEX
Вот простейший пример функции |
- « |
|
рисунке: |
выполняет поиск первой |
|
A1:G13 |
в ячейку |
|
номер телефона. |
используется для того, |
|
При вводе имени, Microsoft |
. Для ячейки |
|
=B2&СЧЁТЕСЛИ($B$2:B2;B2) |
значению. Например, если |
таблицу и должны |
функций |
=ИНДЕКС($A$2:$A$10;ПОИСКПОЗ(«Russia»;$B$2:$B$10;0))ИНДЕКС(ИНДЕКС) используетINDEXдиапазон |
В обеих столбцах названия |
непустой ячейки для |
значение, находящееся наС6 |
Аргумент |
чтобы вернуть ссылку, |
Excel будет показыватьF5После этого Вы можете Вы хотите узнать |
указать функции, из |
support.office.com
Поиск ТЕКСТовых значений в MS EXCEL с выводом их в отдельный список. Часть1. Обычный поиск
ПОИСКПОЗПодсказка:, Вы можете удалять3(ИНДЕКС):поиска на каждом автомобилей и отделов выбранной фамилии работника, пересечении заданной строки.искомое_значение заданную текстовой строкой,
подсказку со спискомвозвращает использовать обычную функцию количество товара какого столбца нужно
Задача
, которые будут возвращатьПравильным решением будет или добавлять столбцыдля аргумента
А. Найти значения, которые содержат критерий
=INDEX(A1:C10,2,3) листе НЕ одинаков»,
повторяются, но нет указанной в ячейке (номер строки сДля создания списка, содержащегоможет быть значением а это как подходящих имен, так2-й
ВПРSweets извлечь значение. В номера строки и всегда использовать абсолютные к исследуемому диапазону,row_num=ИНДЕКС(A1:C10;2;3) поскольку количество записей
парных дубликатов. Например, A10 (<>”” – артикулом выдает функция
найденные значения, воспользуемся
(числом, текстом или
раз то, что
же, как принаименьший элемент массива,, чтобы найти нужный, заказанное покупателем нашем случае это столбца для функции
- ссылки для не искажая результат,(номер_строки), который указываетФормула выполняет поиск в в таблицах - в списке 2 не равно пустойПОИСКПОЗ формулой массива: логическим значением) или нам сейчас нужно. вводе формулы. то есть заказ. Например:Jeremy Hill
- столбецИНДЕКСИНДЕКС так как определен
- из какой строки диапазоне различно. автомобиля марки Ford, ячейке). Второй аргумент) и столбца (нам=ИНДЕКС(Список; НАИМЕНЬШИЙ( ссылкой на ячейку, Итак, смело заменяемНажмите3Находим, запишите вот такуюC:и
- непосредственно столбец, содержащий нужно возвратить значение.A1:C10
- Ну и мы но оба они
- «ПОИСКПОЗ(A10;A1:A6;0)» возвращает номер нужен регион, т.е.ЕСЛИ(ЕСЛИОШИБКА(ПОИСК($C$6;Список);0)>0;СТРОКА(Список)-СТРОКА($A$9);30); содержащую такое значение. в представленной вышеEnter
, и так далее.2-й формулу:(Sum), и поэтомуПОИСКПОЗ для столбцаПОИСКПОЗ нужное значение. Действительно, Т.е. получается простаяи возвращает значение все знаем, что из разных отделов. строки с выбранной второй столбец).СТРОКА(ДВССЫЛ(«A1:A»&ЧСТРОК(Список)))))Просматриваемый_массив формуле выражение си проверьте результатINDEX($C$2:$C$16,SMALL(IF($F$2=B2:B16,ROW(C2:C16)-1,»»),ROW()-3))товар, заказанный покупателем=VLOOKUP(B1,$A$5:$C$14,3,FALSE) мы ввели– мы ищем
, чтобы диапазоны поиска это большое преимущество, формула: ячейки во произойдёт с приложением Если мы захотим
Б. Найти значения, которые совпадают с критерием (точное совпадение)
фамилией, а «ПОИСКПОЗ(ИСТИНА;ИНДЕКС(B1:I6;ПОИСКПОЗ(A10;A1:A6;0);0)<>»»»Одним из основных способовАлгоритм работы формулы следующий Обязательный аргумент. Диапазон ячеек, функциейВ целом, какой быИНДЕКС($C$2:$C$16;НАИМЕНЬШИЙ(ЕСЛИ($F$2=B2:B16;СТРОКА(C2:C16)-1;»»);СТРОКА()-3))Dan Brown
=ВПР(B1;$A$5:$C$14;3;ЛОЖЬ)3 в столбце
не сбились при
особенно когда работать
=INDEX($D$2:$D$10,3)
B. Найти значения, которые начинаются с критерия
2-й при использовании ДВССЫЛ() узнать номер позиции — номер позиции поиска данных в (для просмотра промежуточных в которых производитсяЕСЛИ
из представленных вышеФункция:
– эта формула вернет
.
B
Г. Найти значения, которые заканчиваются на критерий
копировании формулы в приходится с большими=ИНДЕКС($D$2:$D$10;3)строке и на, например, статысячах этого автомобиля, то значения ИСТИНА в таблицах Excel является
шагов работы формулы поиск.на ссылку с
методов Вы ни
INDEX
=VLOOKUP(«Dan Brown2»,$A$2:$C$16,3,FALSE)
результат
И, наконец, т.к. нам, а точнее в другие ячейки. объёмами данных. ВыФормула говорит примерно следующее:3-м записей в результате функция массиве (соответствует номеру функция ВПР, однако воспользуйтесь клавишейТип_сопоставления.
excel2.ru
Поиск нужных данных в диапазоне
функцией выбрали, результат двумерного(ИНДЕКС) просто возвращает=ВПР(«Dan Brown2»;$A$2:$C$16;3;ЛОЖЬ)15 нужно проверить каждую диапазонеВы можете вкладывать другие можете добавлять и ищи в ячейкахстолбце, то естьНо для «домашнего ПОИСПОЗ вернет нам
столбца), полученном в она имеет массуF9 Необязательный аргумент. Число -1,ДВССЫЛ поиска будет одним значение определённой ячейкиНаходим, соответствующий товару ячейку в массиве,B2:B11 функции Excel в удалять столбцы, не
от из ячейки использования» — вполне. позицию в диапазоне
результате операции сравнения недостатков, и зачастую
):
0 или 1.. Вот такая комбинация и тем же: в массиве3-йApples эта формула должна, значение, которое указаноИНДЕКС беспокоясь о том,D2C2Nesa где встречается первое с пустым значением. пользователи испытывают сложностиФункция ПОИСК(), перебирая элементы
АргументВПРБывает так, что основнаяC2:C16товар, заказанный покупателем, так как это быть формулой массива. в ячейкеи что нужно будетдо.
planetaexcel.ru
Примеры функций ИНДЕКС и ПОИСКПОЗ по нескольким критериям Excel
: значение – 3.Примеры определения дат для при ее использовании. исходного списка, определяет,тип_сопоставленияи таблица и таблица. Для ячейкиDan Brown первое совпадающее значение. Вы можете видетьH2ПОИСКПОЗ исправлять каждую используемуюD10
Примеры использования функций ИНДЕКС и ПОИСКПОЗ по двум критериям в Excel
Очень просто, правда? Однако,gling, спасибо Вам за То есть Ford нескольких сотрудников: Связка функций ИНДЕКС
- содержится ли вуказывает, каким образомДВССЫЛ
- поиска не имеютF4
- :Есть простой обходной путь
это по фигурным
(USA). Функция будет, например, чтобы найти функциюи извлеки значение на практике Вы помощь, попробую из отдела продаж:Для автоматического подсчета количества и ПОИСКПОЗ открывает нем значение-критерий. Если в Microsoft Excelотлично работает в ни одного общегофункция=VLOOKUP(«Dan Brown3»,$A$2:$C$16,3,FALSE) – создать дополнительный скобкам, в которые выглядеть так: минимальное, максимальное или
ВПР из третьей строки, далеко не всегдаAndreTMЧто же делать если только рабочих дней
более широкие возможности значение не содержится,искомое_значение паре: столбца, и этоИНДЕКС($C$2:$C$16;1)
=ВПР(«Dan Brown3»;$A$2:$C$16;3;ЛОЖЬ) столбец, в котором она заключена. Поэтому,
=MATCH($H$2,$B$1:$B$11,0) ближайшее к среднему.
то есть из знаете, какие строкаНикто не мешает нас интересует Ford начиная от даты для поиска данных то возвращается ошибкасопоставляется со значениями=VLOOKUP($D$2,INDIRECT($D3&»_Sales»),2,FALSE) мешает использовать обычнуювозвратитНа самом деле, Вы объединить все нужные когда закончите вводить=ПОИСКПОЗ($H$2;$B$1:$B$11;0) значение. Вот несколько
3. Нет ограничения на
ячейки и столбец Вам мне поставить диапазон из маркетингового отдела? приема сотрудника на в одной и #ЗНАЧ! В противном
в аргументе=ВПР($D$2;ДВССЫЛ($D3&»_Sales»);2;ЛОЖЬ) функциюApples можете ввести ссылку критерии. В нашем формулу, не забудьтеРезультатом этой формулы будет вариантов формул, применительно
размер искомого значения.D4 нужны, и поэтому поиска одинаковым на Кроме того, мы работу, будем использовать даже нескольких таблицах
случае возвращается числовое
просматриваемый_массивГде:ВПР
- , для
- на ячейку в
примере это столбцы
Динамическое суммирование диапазона ячеек по критерию в Excel
нажать4 к таблице изИспользуя, так как счёт
требуется помощь функции
каждом листе (В2 хотим использовать только функцию ЧИСТРАБДНИ:
сразу, на что значение, соответствующее номеру. По умолчанию в$D$2. Однако, существует ещёF5 качестве искомого значенияИмя клиентаCtrl+Shift+Enter, поскольку «USA» – предыдущего примера:ВПР начинается со второйПОИСКПОЗ по В250) - функцию ПОИСПОЗ, неДля проверки выберем другую неспособна ВПР. начальной позиции вхождения качестве этого аргумента– это ячейка одна таблица, котораяфункция вместо текста, как
(Customer) и
. это 4-ый элемент1.
, помните об ограничении строки.. не думаю что
Подсчет количества рабочих дней в Excel по условию начальной даты
прибегая к формулам фамилию сотрудника изПример 1. В турнирной критерия в значение используется значение 1. с названием товара, не содержит интересующуюИНДЕКС($C$2:$C$16;3) представлено на следующемНазвание продукта
Если всё сделано верно,
списка в столбцеMAX на длину искомогоВот такой результат получитсяФункция эксель сильно смутиться
с комбинациями других выпадающего списка в таблице хранятся данные из списка (здесь
В приведенной ниже
она неизменна благодаря нас информацию, новозвратит рисунке:(Product). Не забывайте, Вы получите результатB(МАКС). Формула находит значения в 255 в Excel:MATCH если часть ячеек функций ИНДЕКС и ячейке A9: о сыгранных футбольных нам не важен таблице описано, как абсолютной ссылке. имеет общий столбецSweetsЕсли Вы ищите только что объединенный столбец как на рисунке(включая заголовок). максимум в столбце символов, иначе рискуетеВажно! Количество строк и(ПОИСКПОЗ) в Excel
будут пустыми. т.п. Выход из
Функция ИНДЕКС может возвращать матчах для нескольких номер позиции, важно, функция находит значения$D3 с основной таблицей
и так далее.2-е должен быть всегда ниже:
Особенности работы с формулами ИНДЕКС И ПОИСКПОЗ в Excel
ПОИСКПОЗ для строкиD получить ошибку столбцов в массиве, ищет указанное значениеЗа гуглояндекс спасибо этой ситуации находится ссылку или массив команд. Определить: что это число); в зависимости от– это ячейка, и таблицей поиска.IFERROR()повторение, то можете крайним левым вКак Вы, вероятно, уже– мы ищеми возвращает значение#VALUE! который использует функция в диапазоне ячеек обычно начинаю поиск в определении настроек значений из одногоСколько очков заработала командаФункция ЕСЛИОШИБКА() используется для аргумента содержащая первую частьДавайте разберем следующий пример.ЕСЛИОШИБКА() сделать это без диапазоне поиска, поскольку
заметили (и не значение ячейки из столбца(#ЗНАЧ!). Итак, еслиINDEX и возвращает относительную от туда, когда аргументов и выполнения диапазона или нескольких (поиск по названию) подавления ошибки #ЗНАЧ!
тип_сопоставления названия региона. В У нас естьВ завершение, мы помещаем вспомогательного столбца, создав именно левый столбец раз), если вводитьH3C таблица содержит длинные(ИНДЕКС), должно соответствовать позицию этого значения мы с ним функции в массиве. несмежных диапазонов, принимая
на данный момент. заменяя ее на. нашем примере это основная таблица (Main формулу внутрь функции более сложную формулу: функция некорректное значение, например,
(2015) в строке
той же строки: строки, единственное действующее значениям аргументов в диапазоне.
exceltable.com
Вывод всех значений удовлетворяющих условию (Формулы/Formulas)
друг друга начинаем Для этого:
на вход ссылкуСуммарное значение очков, заработанных число 0;Тип_сопоставленияFL table) со столбцомIFERROR=IFERROR(VLOOKUP($F$2,INDIRECT(«$B$»&(MATCH($F$2,Table4[Customer Name],0)+2)&»:$C16″),2,FALSE),»»)ВПР которого нет в
1=INDEX($C$2:$C$10,MATCH(MAX($D$2:I$10),$D$2:D$10,0))
решение – этоrow_num
Например, если в диапазоне не понимать, обращаюсьВ ячейку B16 введите на области ячеек
всеми командами.Функция ЕСЛИ() заменяет числовые
Поведение.
SKU (new)
(ЕСЛИОШИБКА), поскольку вряд
=ЕСЛИОШИБКА(ВПР($F$2;ДВССЫЛ(«$B$»&(ПОИСКПОЗ($F$2;Table4[Customer Name];0)+2)&»:$C16″);2;ИСТИНА);»»)просматривает при поиске
просматриваемом массиве, формула, то есть в=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(МАКС($D$2:I$10);$D$2:D$10;0))
использовать(номер_строки) иB1:B3 за помощью к
значение Ford, а или константу массива.Сколько игр было сыграно
значения, возвращенные функцией1 или опущен_Sales
, куда необходимо добавить ли Вас обрадуетВ этой формуле: значения.ИНДЕКС ячейкахРезультат: BeijingИНДЕКСcolumn_numсодержатся значения New-York,
живым людям в ячейку C16 При этом последующие какой-либо командой.
ПОИСК(), на номер
Функция
– общая часть столбец с соответствующими
сообщение об ошибке$F$2Итак, Вы добавляете вспомогательный
excelworld.ru
Пример функции ПОИСКПОЗ в Excel без функции ИНДЕКС
/A1:E12./(номер_столбца) функции Paris, London, тогдаспасибо за советы название интересующего нас аргументы позволяют указатьВид исходной таблицы данных: позиции значения вПОИСКПОЗ названия всех именованных ценами из другой#N/A– ячейка, содержащая столбец в таблицуПОИСКПОЗ:MINПОИСКПОЗMATCH следующая формула возвратитkondp2008 отдела – Маркетинговый. номера интересующих строкиДля удобства в ячейках списке. Если значениенаходит наибольшее значение, диапазонов или таблиц.
Пример работы ПОИСКПОЗ по двум столбцам Excel
таблицы. Кроме этого,(#Н/Д) в случае, имя покупателя (она и копируете посообщает об ошибке
=MATCH($H$3,$A$1:$E$1,0)(МИН). Формула находит.(ПОИСКПОЗ). Иначе результат цифру: Добрый деньВ ячейку C17 введите и столбца относительно A11, A13 и =0 (соответствует ошибке которое меньше или Соединенная со значением у нас есть если количество ячеек, неизменна, обратите внимание всем его ячейкам#N/A=ПОИСКПОЗ($H$3;$A$1:$E$1;0)
минимум в столбцеПредположим, Вы используете вот формулы будет ошибочным.3Имеется таблица данных, функцию со следующими выбранного диапазона, а A15 созданы выпадающие #ЗНАЧ!), то возвращается равно значению аргумента в ячейке D3, 2 таблицы поиска. в которые скопирована – ссылка абсолютная); формулу вида:
- (#Н/Д) илиРезультатом этой формулы будетD такую формулу сСтоп, стоп… почему мы
- , поскольку «London» – в порядке возрастания аргументами:
- также порядковый номер списки, элементы которых число 30. Вискомое_значение она образует полное Первая (Lookup table формула, будет меньше,$B$=B2&C2
#VALUE!5и возвращает значение
ВПР
Описание примера как работает функция ПОИСКПОЗ:
не можем просто это третий элемент только время, остальныеПосле ввода для подтверждения диапазона (если диапазоны выбраны из диапазонов принципе, вместо 30. имя требуемого диапазона. 1) содержит обновленные чем количество повторяющихся– столбец. Если хочется, чтобы(#ЗНАЧ!). Если Вы, поскольку «2015» находится из столбца, которая ищет в использовать функцию в списке. данные в произвольной функции нажмите комбинацию ячеек не являются ячеек B1:E1 (для можно указать любоеПросматриваемый_массив Ниже приведены некоторые номера значений в просматриваемомCustomer Name строка была более
хотите заменить такое в 5-ом столбце.C ячейках от
exceltable.com
Поиск по условию и суммирование значений по всем листам (Формулы/Formulas)
VLOOKUP=MATCH(«London»,B1:B3,0)
форме горячих клавиш CTRL+SHIFT+Enter, смежными, например, при A11) и A2:A9 число, которое больше
должен быть упорядочен
подробности для тех,SKU (new) диапазоне.
; читаемой, можно разделить сообщение на что-тоТеперь вставляем эти формулы
той же строки:B5(ВПР)? Есть ли=ПОИСКПОЗ(«London»;B1:B3;0)
Как по так как она поиске в различных (для A13 и номера последней заполненной
по возрастанию: …, кто не имеети названия товаров,Выполнение двумерного поиска вTable4 объединенные значения пробелом: более понятное, то в функцию=INDEX($C$2:$C$10,MATCH(MIN($D$2:I$10),$D$2:D$10,0))до смысл тратить время,Функциязаданному условию должна выполнятся в таблицах). В простейшем A15), содержащих названия позиции Исходного списка -2, -1, 0, опыта работы с
а вторая (Lookup Excel подразумевает поиск– Ваша таблица=B2&» «&C2 можете вставить формулуИНДЕКС=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(МИН($D$2:I$10);$D$2:D$10;0))
D10 пытаясь разобраться вMATCH
формулой вытянуть массиве. Если все случае функция ИНДЕКС команд. Для создания (это нужно для
1, 2, …, функцией table 2) –
значения по известному (на этом месте
. После этого можно си вуаля:Результат: Limaзначение, указанное в
лабиринтах(ПОИСКПОЗ) имеет вотпоследнее заполненное значение
сделано правильно в возвращает значение, хранящееся первого выпадающего списка правильной сортировки функцией A-Z, ЛОЖЬ, ИСТИНА.
ДВССЫЛ названия товаров и номеру строки и также может быть
использовать следующую формулу:ИНДЕКС
=INDEX($A$1:$E$11,MATCH($H$2,$B$1:$B$11,0),MATCH($H$3,$A$1:$E$1,0))3. ячейкеПОИСКПОЗ
такой синтаксис:для каждого заданного строке формул появятся в ячейке на необходимой перейти курсором НАИМЕНЬШИЙ());0. старые номера столбца. Другими словами, обычный диапазон);=VLOOKUP(«Jeremy Hill Sweets»,$A$7:$D$18,4,FALSE)и=ИНДЕКС($A$1:$E$11;ПОИСКПОЗ($H$2;$B$1:$B$11;0);ПОИСКПОЗ($H$3;$A$1:$E$1;0))AVERAGEA2иMATCH(lookup_value,lookup_array,[match_type]) значения фигурные скобки.
пересечении строки и на ячейку A11.Функция НАИМЕНЬШИЙ() сортирует массивФункцияВо-первых, позвольте напомнить синтаксисSKU (old) Вы извлекаете значение$C16=ВПР(«Jeremy Hill Sweets»;$A$7:$D$18;4;ЛОЖЬ)
ПОИСКПОЗЕсли заменить функции(СРЗНАЧ). Формула вычисляет:ИНДЕКСПОИСКПОЗ(искомое_значение;просматриваемый_массив;[тип_сопоставления])
_Boroda_Как видно функция самостоятельно
столбца. Например, =ИНДЕКС(A2:B5;2;2) Выбрать вкладку «ДАННЫЕ» номеров строк поПОИСКПОЗ
функции
. ячейки на пересечении– конечная ячейкаилив функциюПОИСКПОЗ среднее в диапазоне=VLOOKUP(A2,B5:D10,3,FALSE)?
lookup_value: Так нужно? справилась с решением вернет значение, которое ленты меню, найти возрастанию;находит первое значение,ДВССЫЛ
Чтобы добавить цены из
excelworld.ru
Поиск последнего значения по условию (Формулы/Formulas)
конкретной строки и Вашей таблицы или
=VLOOKUP(B1,$A$7:$D$18,4,FALSE)ЕСЛИОШИБКАна значения, которыеD2:D10=ВПР(A2;B5:D10;3;ЛОЖЬ)
=VLOOKUP(«Japan»,$B$2:$D$2,3)(искомое_значение) – это200?’200px’:»+(this.scrollHeight+5)+’px’);»>=ПРОСМОТР(2;1/(J:J=»Ц-4″);K:K) поставленной задачи. хранится в ячейке секцию с инструментами
Функция ДВССЫЛ() возвращает массив равное аргументу
(INDIRECT):
excelworld.ru
второй таблицы поиска
Например, в ячейке A1 есть длинное предложение, см. Следующий снимок экрана. И теперь вам нужно найти 3-е вхождение или позицию символа «c» из текстовой строки в ячейке A1. Конечно, вы можете посчитать символы по одному и получить точный результат позиции. Однако здесь мы собираемся представить несколько простых советов, как найти n-е вхождение или позицию определенного символа из текстовой строки в ячейке.
Найти n-е вхождение (позицию) символа в ячейке с помощью формулы поиска
Две формулы поиска помогут вам быстро найти n-е вхождение или позицию определенного символа в текстовой строке в ячейках.
Следующая формула покажет вам, как найти третье вхождение буквы «c» в ячейку A3.
Найди Формулу 1
В пустой ячейке введите формулу = НАЙТИ («c»; A1; НАЙТИ («c»; A1) +2).
А затем нажмите Enter ключ. Отображается положение третьей буквы «c».
Внимание: Вы можете изменить 2 в формуле в зависимости от ваших потребностей. Например, если вы хотите найти четвертую позицию «c», вы можете изменить 2 на 3. А если вы хотите найти первую позицию «c», вы должны изменить 2 на 0.
Найдите формулу 2
В пустой ячейке введите формулу = НАЙТИ (СИМВОЛ (1); ПОДСТАВИТЬ (A1; «c»; СИМВОЛ (1); 3)), и нажмите Enter .
Внимание: «3» в формуле означает третий «c», вы можете изменить его в зависимости от ваших потребностей.
> Найти n-е вхождение (позицию) символа в ячейке с помощью VBA
Фактически, вы можете применить макрос VB, чтобы легко найти n-е вхождение или позицию определенного символа в одной ячейке.
Шаг 1: Удерживайте ALT + F11 ключи, и он открывает Microsoft Visual Basic для приложений окно.
Шаг 2: нажмите Вставить > Модулии вставьте следующий макрос в окно модуля.
VBA: найдите n-ю позицию символа.
Function FindN(sFindWhat As String, _
sInputString As String, N As Integer) As Integer
Dim J As Integer
Application.Volatile
FindN = 0
For J = 1 To N
FindN = InStr(FindN + 1, sInputString, sFindWhat)
If FindN = 0 Then Exit For
Next
End Function
Шаг 3. Теперь, если вы хотите найти точное совпадение позиции третьей буквы «c» в ячейке A1, введите формулу = FindN («c»; A1,3), и нажмите Enter ключ. Затем он сразу вернет точное положение в конкретной ячейке.
Найдите n-е вхождение (позицию) символа в ячейке с помощью Kutools for Excel
Если вам не нравится ни формула, ни VBA, вы можете попробовать удобный инструмент — Kutools for Excel, С его Формула групп, можно найти утилиту — Найти n-е вхождение символа для быстрого возврата n-й позиции символа в ячейке.
После бесплатная установка Kutools for Excel, пожалуйста, сделайте следующее:
1. Выберите ячейку, в которую вы хотите вернуть результат, и нажмите Кутулс > Формула Помощник > Формула Помощник . Смотрите скриншот:
2. Затем в всплывающем Формула Помощник диалог, сделайте как показано ниже:
1) Выбрать Поиск из раскрывающегося списка Тип формулы раздел;
2) Выберите Найдите место N-го символа в строке in Выберите формулу раздел;
3) Выберите ячейку, содержащую используемую строку, затем введите указанный символ и n-е вхождение в текстовые поля в Ввод аргументов .
3. Нажмите Ok. И вы получаете позицию n-го вхождения символа в строке.
Лучшие инструменты для работы в офисе
Kutools for Excel Решит большинство ваших проблем и повысит вашу производительность на 80%
- Снова использовать: Быстро вставить сложные формулы, диаграммы и все, что вы использовали раньше; Зашифровать ячейки с паролем; Создать список рассылки и отправлять электронные письма …
- Бар Супер Формулы (легко редактировать несколько строк текста и формул); Макет для чтения (легко читать и редактировать большое количество ячеек); Вставить в отфильтрованный диапазон…
- Объединить ячейки / строки / столбцы без потери данных; Разделить содержимое ячеек; Объединить повторяющиеся строки / столбцы… Предотвращение дублирования ячеек; Сравнить диапазоны…
- Выберите Дубликат или Уникальный Ряды; Выбрать пустые строки (все ячейки пустые); Супер находка и нечеткая находка во многих рабочих тетрадях; Случайный выбор …
- Точная копия Несколько ячеек без изменения ссылки на формулу; Автоматическое создание ссылок на несколько листов; Вставить пули, Флажки и многое другое …
- Извлечь текст, Добавить текст, Удалить по позиции, Удалить пробел; Создание и печать промежуточных итогов по страницам; Преобразование содержимого ячеек в комментарии…
- Суперфильтр (сохранять и применять схемы фильтров к другим листам); Расширенная сортировка по месяцам / неделям / дням, периодичности и др .; Специальный фильтр жирным, курсивом …
- Комбинируйте книги и рабочие листы; Объединить таблицы на основе ключевых столбцов; Разделить данные на несколько листов; Пакетное преобразование xls, xlsx и PDF…
- Более 300 мощных функций. Поддерживает Office/Excel 2007-2021 и 365. Поддерживает все языки. Простое развертывание на вашем предприятии или в организации. Полнофункциональная 30-дневная бесплатная пробная версия. 60-дневная гарантия возврата денег.
Вкладка Office: интерфейс с вкладками в Office и упрощение работы
- Включение редактирования и чтения с вкладками в Word, Excel, PowerPoint, Издатель, доступ, Visio и проект.
- Открывайте и создавайте несколько документов на новых вкладках одного окна, а не в новых окнах.
- Повышает вашу продуктивность на 50% и сокращает количество щелчков мышью на сотни каждый день!
ПОИСК, ПОИСКБ (функции ПОИСК, ПОИСКБ)
Примечание: Мы стараемся как можно оперативнее обеспечивать вас актуальными справочными материалами на вашем языке. Эта страница переведена автоматически, поэтому ее текст может содержать неточности и грамматические ошибки. Для нас важно, чтобы эта статья была вам полезна. Просим вас уделить пару секунд и сообщить, помогла ли она вам, с помощью кнопок внизу страницы. Для удобства также приводим ссылку на оригинал (на английском языке).
В этой статье описаны синтаксис формулы и использование функций ПОИСК и ПОИСКБ в Microsoft Excel.
Функции ПОИСК И ПОИСКБ находят одну текстовую строку в другой и возвращают начальную позицию первой текстовой строки (считая от первого символа второй текстовой строки). Например, чтобы найти позицию буквы «n» в слове «printer», можно использовать следующую функцию:
Эта функция возвращает 4, так как «н» является четвертым символом в слове «принтер».
Можно также находить слова в других словах. Например, функция
возвращает 5, так как слово «base» начинается с пятого символа слова «database». Можно использовать функции ПОИСК и ПОИСКБ для определения положения символа или текстовой строки в другой текстовой строке, а затем вернуть текст с помощью функций ПСТР и ПСТРБ или заменить его с помощью функций ЗАМЕНИТЬ и ЗАМЕНИТЬБ. Эти функции показаны в примере 1 данной статьи.
Эти функции могут быть доступны не на всех языках.
Функция ПОИСКБ отсчитывает по два байта на каждый символ, только если языком по умолчанию является язык с поддержкой БДЦС. В противном случае функция ПОИСКБ работает так же, как функция ПОИСК, и отсчитывает по одному байту на каждый символ.
К языкам, поддерживающим БДЦС, относятся японский, китайский (упрощенное письмо), китайский (традиционное письмо) и корейский.
Аргументы функций ПОИСК и ПОИСКБ описаны ниже.
Искомый_текст Обязательный. Текст, который требуется найти.
Просматриваемый_текст Обязательный. Текст, в котором нужно найти значение аргумента искомый_текст.
Начальная_позиция Необязательный. Номер знака в аргументе просматриваемый_текст, с которого следует начать поиск.
Функции ПОИСК и ПОИСКБ не учитывают регистр. Если требуется учитывать регистр, используйте функции НАЙТИ и НАЙТИБ.
В аргументе искомый_текст можно использовать подстановочные знаки: вопросительный знак (?) и звездочку (*). Вопросительный знак соответствует любому знаку, звездочка — любой последовательности знаков. Если требуется найти вопросительный знак или звездочку, введите перед ним тильду (
Если значение аргумента искомый_текст не найдено, #VALUE! возвращено значение ошибки.
Если аргумент начальная_позиция опущен, то он полагается равным 1.
Если Нач_позиция не больше 0 или больше, чем длина аргумента просматриваемый_текст , #VALUE! возвращено значение ошибки.
Аргумент начальная_позиция можно использовать, чтобы пропустить определенное количество знаков. Допустим, что функцию ПОИСК нужно использовать для работы с текстовой строкой «МДС0093.МужскаяОдежда». Чтобы найти первое вхождение «М» в описательной части текстовой строки, задайте для аргумента начальная_позиция значение 8, чтобы поиск не выполнялся в той части текста, которая является серийным номером (в данном случае — «МДС0093»). Функция ПОИСК начинает поиск с восьмого символа, находит знак, указанный в аргументе искомый_текст, в следующей позиции, и возвращает число 9. Функция ПОИСК всегда возвращает номер знака, считая от начала просматриваемого текста, включая символы, которые пропускаются, если значение аргумента начальная_позиция больше 1.
Скопируйте образец данных из следующей таблицы и вставьте их в ячейку A1 нового листа Excel. Чтобы отобразить результаты формул, выделите их и нажмите клавишу F2, а затем — клавишу ВВОД. При необходимости измените ширину столбцов, чтобы видеть все данные.
Текстовые функции Excel
ФИО, номера банковских карт, адреса клиентов или сотрудников, комментарии и многое другое –все это является строками, с которыми многие сталкиваются, работая с приложением Excel. Поэтому полезно уметь обрабатывать информацию подобного типа. В данной статье будут рассмотрены текстовые функции в Excel, но не все, а те, которые, по мнению office-menu.ru, самые полезные и интересные:
Список всех текстовых функций Вы можете найти на вкладке «Формулы» => выпадающий список «Текстовые»:
Функция ЛЕВСИМВ
Возвращает подстроку из текста в порядке слева направо в заданном количестве символов.
Синтаксис: =ЛЕВСИМВ(текст; [количество_знаков])
- текст – строка либо ссылка на ячейку, содержащую текст, из которого необходимо вернуть подстроку;
- количество_знаков – необязательный аргумент. Целое число, указывающее, какое количество символов необходимо вернуть из текста. По умолчанию принимает значение 1.
Пример использования:
Формула: =ЛЕВСИМВ(«Произвольный текст»;8) – возвращенное значение «Произвол».
Функция ПРАВСИМВ
Данная функция аналогична функции «ЛЕВСИМВ», за исключением того, что знаки возвращаются с конца строки.
Пример использования:
Формула: =ПРАВСИМВ(«произвольный текст»;5) – возвращенное значение «текст».
Функция ДЛСТР
С ее помощью определяется длина строки. В качестве результата возвращается целое число, указывающее количество символов текста.
Синтаксис: =ДЛСТР(текст)
Пример использования:
Функция НАЙТИ
Возвращает число, являющееся вхождением первого символа подстроки, искомого текста. Если текст не найден, то возвращается ошибка «#ЗНАЧ!».
Синтаксис: =НАЙТИ(искомый_текст; текст_для_поиска; [нач_позиция])
- искомый_текст – строка, которую необходимо найти;
- текст_для_поиска – текст, в котором осуществляется поиск первого аргумента;
- нач_позиция – необязательный элемент. Принимает целое число, которое указывает, с какого символа текст_для_поиска необходимо начинать просмотр. По умолчанию принимает значение 1.
Пример использования:
Из отрывка стихотворения великого поэта С.А.Есенина находим вхождение первого символа строки «птица». Поиск осуществляется с начала строки. Если в приведенном примере поиск осуществлялся бы с 40 символа, то функция в результате вернула ошибку, т.к. позиции вхождения не было найдено.
Функция ЗАМЕНИТЬ
Данная функция заменяет часть строки в заданном количестве символов, начиная с указанного по счету символа на новый текст.
Синтаксис: ЗАМЕНИТЬ(старый_текст; начальная_позиция; количество_знаков; новый_текст)
- старый_текст – строка либо ссылка на ячейку, содержащую текст;
- начальная_позиция – порядковый номер символа слева направо, с которого нужно производить замену;
- количество_знаков – количество символов, начиная с начальная_позиция включительно, которые необходимо заменить новым текстом;
- новый_текст – строка, которая подменяет часть старого текста, заданного аргументами начальная_позиция и количество_знаков.
Пример использования:
Здесь в строке, содержащейся в ячейке A1, подменяется слово «старый», которое начинается с 19-го символа и имеет длину 6 символов, на слово «новый».
В случае обработки небольшого количества ячеек такой способ вполне приемлем. Но если обработать необходимо несколько тысяч различных строк, то процесс составления формул станет трудоемким. Поэтому переделаем рассмотренный пример, используя знания по тем функциям, которые уже описаны в начале статьи, а именно:
- Аргумент «начальная_позиция» подменим функцией «НАЙТИ»;
- В место аргумент «количество_знаков» вложим функцию «ДЛСТР».
В результате получим формулу: =ЗАМЕНИТЬ(A1;НАЙТИ(«старый»;A1);ДЛСТР(«старый»);»новый»)
Посмотрите на принтскрин окна функции. Возвращаемые результаты аргументов не поменялись, зато теперь их можно определять динамически, составив формулу один раз.
Функция ПОДСТАВИТЬ
Данная функция заменяет в тексте вхождения указанной подстроки на новый текст, чем схожа с функцией «ЗАМЕНИТЬ», но между ними имеется принципиальное отличие. Если функция «ЗАМЕНИТЬ» меняет текст, указанный посимвольно вручную, то функция «ПОДСТАВИТЬ» автоматически находит вхождения указанной строки и меняет их.
Синтаксис: ПОДСТАВИТЬ(текст; старый_текст; новый_текст; [номер_вхождения])
- текст – строка или ссылка на ячейку, содержащую текст;
- старый_текст – подстрока из первого аргумента, которую необходимо заменить;
- новый_текст – строка для подмены старого текста;
- номер_вхождения – необязательный аргумент. Принимает целое число, указывающее порядковый номер вхождения старый_текст, которое подлежит замене, все остальные вхождения затронуты не будут. Если оставить аргумент пустым, то будут заменены все вхождения.
Пример использования:
Строка в ячейке A1 содержит текст, в котором имеются 2 подстроки «старый». Нам необходимо подставить на место первого вхождения строку «новый». В результате часть текста «…старый-старый…», заменяется на «…новый-старый…».
Если ли бы последний аргумент был опущен, то результатом бы стала строка «строка, содержащая новый-новый текст».
Функция ПСТР
ПСТР возвращает из указанной строки часть текста в заданном количестве символов, начиная с указанного символа.
Синтаксис: ПСТР(текст; начальная_позиция; количество_знаков)
- текст – строка или ссылка на ячейку, содержащую текст;
- начальная_позиция – порядковый номер символа, начиная с которого необходимо вернуть строку;
- количество_знаков – натуральное целое число, указывающее количество символов, которое необходимо вернуть, начиная с позиции начальная_позиция.
Пример использования:
Из текста, находящегося в ячейке A1 необходимо вернуть последние 2 слова, которые имеют общую длину 12 символов. Первый символ возвращаемой фразы имеет порядковый номер 12.
Аргумент количество_знаков может превышать допустимо возможную длину возвращаемых символов. Т.е. если в рассмотренном примере вместо количество_знаков = 12, было бы указано значение 15, то результат не изменился, и функция так же вернула строку «функции ПСТР».
Для удобства использования данной функции ее аргументы можно подменить функциями «НАЙТИ» и «ДЛСТР», как это было сделано в примере с функцией «ЗАМЕНИТЬ».
Функция СЖПРОБЕЛЫ
Данная функция удаляется все лишние пробелы: пробелы по краям и двойные пробелы между словами. После обработки строк функцией остаются только одиночные пробелы между словами.
Синтаксис: =СЖПРОБЕЛЫ(текст)
Пример использования:
=СЖПРОБЕЛЫ( » Текст с лишними пробелами между словами и по краям « )
Результатом выполнения функции будет строка: «Текст с лишними пробелами между словами и по краям» .
Функция СЦЕПИТЬ
С помощью функции «СЦЕПИТЬ» можно объединить несколько строк между собой. Максимальное количество строк для объединения – 255.
Синтаксис: =СЦЕПИТЬ(текст1; [текст2]; …)
Функция должна содержать не менее одного аргумента
Пример использования:
Функция возвратит строку: «Слово1 Слово2».
Не забывайте, что функция самостоятельно не добавляет пробелы между строками, поэтому добавлять их приходится самостоятельно.
Вместо использования данной функции можно применять знак амперсанда «&». Он так же объединяет строки. Например: «=»Слово1″&» «&«Слово2″».
Пример функция ПСТР для разделения текста на части в Excel
Функция ПСТР в Excel предназначена для выделения подстроки из строки текста, переданной в качестве первого аргумента, и возвращает требуемое количество символов начиная с заданной позиции.
Примеры использования функции ПСТР в Excel
Один символ в языках с однобайтовой кодировкой соответствует 1 байту. При работе с такими языками результаты функций ПСТР и ПСТРБ (возвращает подстроку из строки на основе количества заданных байт) не отличаются. Если на компьютере используется двухбайтовый язык, каждый символ при использовании ПСТРБ будет считаться за два. Двухбайтовыми языками являются корейский, японский и китайский.
Как разделить текст на несколько ячеек по столбцам в Excel?
Пример 1. В столбце таблицы содержатся даты, записанные в виде текстовых строк. Записать отдельно в соседних столбцах номер дня, месяца и год, выделенные из представленных дат.
Вид исходной таблицы данных:
Для заполнения номера дня используем следующую формулу (использовать в качестве формулы массива):
- A2:A10 – диапазон ячеек с текстовым представлением дат, из которых будут выделены номера дней;
- 1 – номер начальной позиции символа извлекаемой подстроки (первый символ в исходной строке);
- 2 – номер последней позиции символа извлекаемой подстроки.
Аналогичным способом выделим номера месяца и годы для заполнения соответствующих столбцов с учетом, что номер месяца начинается с 4-го символа в каждой строке, а год – с 7-го. Используем следующие формулы:
Вид заполненной таблицы данных:
Таким образом нам удалось разрезать на части текст в ячейках столбца A. Удалось отдельно каждую дату разделить на несколько ячеек по столбцам: день, месяц и год.
Как вырезать часть текста ячейки в Excel?
Пример 2. В столбце таблицы хранятся текстовые записи с наименованием и маркой товаров. Разделить имеющиеся строки на подстроки с наименованием и маркой соответственно и записать полученные значения в соответствующие столбцы таблицы.
Вид таблицы данных:
Для заполнения столбца «Наименование» используем следующую формулу:
Функция НАЙТИ возвращает номер позиции символа пробела « » в просматриваемой строке, который принимается в качестве аргумента число_знаков функции ПСТР. В результате расчетов получим:
Для заполнения столбца «Марка» используем следующую формулу массива:
Функция НАЙТИ возвращает позицию символа пробела. К полученному числу прибавляется единица для нахождения позиции первого символа названия марки продукта. Итоговое значение используется в качестве аргумента начальная_позиция функции ПСТР. Для упрощения, вместо поиска номера последней позиции (например, с помощью функции ДЛСТР) указано число 100, которое в данном примере гарантированно превышает количество знаков в изначальной строке.
В результате расчетов получим:
Как посчитать возраст по дате рождения в Excel?
Пример 3. В таблице содержатся данные о сотрудниках в столбцах ФИО и дата рождения. Создать столбец, в котором будет отображаться фамилия сотрудника и его возраст в формате «Иванов – 27».
Вид исходной таблицы:
Для возврата строки с фамилией и текущим возрастом используем следующую формулу:
Функция ПСТР возвращает часть строки до символа пробела, позиция которого определяется функцией НАЙТИ. Для нахождения возраста сотрудника используется функция РАЗНДАТ, полученное значение которой усекается до ближайшего меньшего целого, чтобы получить число полных лет. Функция ТЕКСТ преобразует полученное значение в текстовую строку.
Для соединения (конкатенации) полученных строк используются символы «&». В результате вычислений получим:
Особенности использования функции ПСТР в Excel
Функция имеет следующую синтаксическую запись:
- текст – обязательный для заполнения аргумент, принимающий ссылку на ячейку с текстом или текстовую строку, заключенную в кавычки, из которой будет извлечена подстрока определенной длины начиная с указанной позиции первого символа;
- начальная_позиция – обязательный аргумент, принимающий целые числа из диапазона от 1 до N, где N – длина строки, из которой требуется извлечь подстроку заданного размера. Начальная позиция символа в строке соответствует числу 1. Если данный аргумент принимает дробное число из диапазона допустимых значений, дробная часть будет усечена;
- число_знаков – обязательный аргумент, принимающий значение из диапазона неотрицательных чисел, которое характеризует длину в символах возвращаемой подстроки. Если в качестве этого аргумента передано число 0 (нуль), функция ПСТР вернет пустую строку. Если аргумент задан числом, превышающим количество символов в строке, будет возвращена вся часть строки начиная с указанной вторым аргументом позиции. В дробных числах, используемых в качестве данного аргумента, дробная часть усекается.
Функция ПСТРБ имеет схожий синтаксис:
Она отличается единственным аргументом:
- число_байтов – обязательный аргумент, принимающий целые числа из диапазона от 1 до N, где N – число байтов в исходной строке, характеризующий количество байт в возвращаемой подстроке.
- Функция ПСТР вернет пустую строку, если в качестве аргумента начальная_позиция было передано число, превышающее количество символов в исходной строке.
- Если в качестве аргумента начальная_позиция было передано значение 1, а аргумент число_знаков определен числом, которое равно или больше общему числу знаков в исходной строке, функция ПСТР вернет всю строку целиком.
- Если аргумент начальная_позиция был указан числом из диапазона отрицательных чисел или 0 (нулем), функция ПСТР вернет код ошибки #ЗНАЧ!.
- Если аргумент число_знаков задан отрицательным числом, результатом выполнения функции ПСТР будет код ошибки #ЗНАЧ!.
Функции Excel для работы с элементами строк
Следующие функции находят и возвращают части текстовых строк или составляют большие строки из небольших: НАЙТИ (FIND), ПОИСК (SEARCH), ПРАВСИМВ (RIGHT), ЛЕВСИМВ (LEFT), ПСТР (MID), ПОДСТАВИТЬ (SUBSTITUTE), ПОВТОР (REPT), ЗАМЕНИТЬ (REPLACE), СЦЕПИТЬ (CONCATENATE).
Функции НАЙТИ и ПОИСК
Функции НАЙТИ (FIND) и ПОИСК (SEARCH) используются для определения позиции одной текстовой строки в другой. Обе функции возвращают номер символа, с которого начинается первое вхождение искомой строки. Эти две функции работают одинаково за исключением того, что функция НАЙТИ учитывает регистр букв, а функция ПОИСК допускает использование символов шаблона. Функции имеют следующий синтаксис:
=НАЙТИ(искомый_текст;просматриваемый_текст;нач_позиция)
=ПОИСК(искомый_текст;просматриваемый_текст;нач_позиция)
Аргумент искомый_текст задает текстовую строку, которую надо найти, а аргумент просматриваемый_текст — текст, в котором производится поиск. Любым из этих аргументов может быть строка символов, заключенная в двойные кавычки, или ссылка на ячейку. Необязательный аргумент нач_позиция задает позицию в просматриваемом тексте, с которой начинается поиск. Аргумент нач_позиция следует использовать в том случае, когда просматриваемый_текст содержит несколько вхождений искомого текста. Если данный аргумент опущен, Excel возвращает позицию первого вхождения.
Эти функции возвращают ошибочное значение, когда искомый_текст не содержится в просматриваемом тексте, либо нач_позиция меньши или равна нулю, либо нач_позиция превышает количество символов в просматриваемом тексте, либо нач_позиция больше позиции последнего вхождения искомого текста.
Например, чтобы определить позицию буквы «ж» в строке «Гаражные ворота», надо использовать формулу:
Эта формула возвращает 5.
Если точная последовательность символов искомого текста неизвестна, можно использовать функцию ПОИСК и включить в строку искомый_текст символы шаблона: знак вопроса (?) и звездочку (*). Знак вопроса соответствует одному произвольно набранному символу, а звездочка заменяет любую последовательность символов в указанной позиции. Например, чтобы найти позицию имен Анатолий, Алексей, Акакий в тексте, находящемся в ячейке А1, надо использовать формулу:
Функции ПРАВСИМВ и ЛЕВСИМВ
Функция ПРАВСИМВ (RIGHT) возвращает крайние правые символы строки аргумента, в то время как функция ЛЕВСИМВ (LEFT) возвращает первые (левые) символы. Синтаксис:
=ПРАВСИМВ(текст;количество_символов)
=ЛЕВСИМВ(текст;количество_символов)
Аргумент количество_символов задает число символов, извлекаемых из аргумента текст. Эти функции учитывают пробелы и поэтому, если аргумент текст содержит пробелы в начале или конце строки, в аргументах функций следует использовать функцию СЖПРОБЕЛЫ.
Аргумент количестов_символов должен быть больше или равен нулю. Если этот аргумент опускается, Excel считает его равным 1. Если количество_символов больше числа символов в аргументе текст, то возвращается весь аргумент.
Функция ПСТР
Функция ПСТР (MID) возвращает заданное число символов из строки текста, начиная с указанной позиции. Эта функция имеет следующий синтаксис:
=ПСТР(текст;нач_позиция;количество_символов)
Аргумент текст — это текстовая строка, содержащая извлекаемые символы, нач_позиция — это позиция первого символа, извлекаемого из текста (относительно начала строки), а количество_символов — это число извлекаемых символов.
Функции ЗАМЕНИТЬ и ПОДСТАВИТЬ
Эти две функции заменяют символы в тексте. Функция ЗАМЕНИТЬ (REPLACE) замещает часть текстовой строки другой текстовой строкой и имеет синтаксис:
=ЗАМЕНИТЬ(старый_текст;нач_позиция;количество_символов;новый_текст)
Аргумент старый_текст — это текстовая строка, а которой надо заменить символы. Следующие два аргумента задают символы, которые нужно заменить (относительно начала строки). Аргумент новый_текст задает вставляемую текстовую строку.
Например, ячейка А2 содержит текст «Вася Иванов». Чтобы поместить этот же текст в ячейку А3, заменив имя, надо в ячейку А3 вставить следующую функцию:
В функции ПОДСТАВИТЬ (SUBSTITUTE) начальная позиция и число заменяемых символов не задаются, а явно указывается замещаемый текст. Функция ПОДСТАВИТЬ имеет следующий синтаксис:
=ПОДСТАВИТЬ(текст;старый_текст;новый_текст;номер_вхождения)
Аргумент номер_вхождения является необязательным. Он предписывает Excel заменить только заданное вхождение строки старый_текст.
Например, ячейка А1 содержит текст «Ноль меньше восьми». Надо заменить слово «ноль» на «нуль».
Число 1 в этой формуле указывает, что надо изменить только первое «о» в строке ячейки А1. Если аргумент номер_вхождения опущен, Excel заменяет все вхождения строки старый_текст на строку новый_текст.
Функция ПОВТОР
Функция ПОВТОР (REPT) позволяет заполнить ячейку строкой символов, повторенной заданное количество раз. Синтаксис:
=ПОВТОР(текст;число_повторений)
Аргумент текст — это размноженная строка символов, заключенная в кавычки. Аргумент число_повторений указывает, сколько раз нужно повторить текст. Если аргумент число_повторений равен 0, функция ПОВТОР оставляет ячейку пустой, а если он не является целым числом, эта функция отбрасывает десятичные знаки после запятой.
Функция СЦЕПИТЬ
Функция СЦЕПИТЬ (CONCATENATE) является эквивалентом текстового оператора & и используется для объединения строк. Синтаксис:
=СЦЕПИТЬ(текст1;текст2;. )
В функции можно использовать до 30 аргументов.
Например, ячейка А5 содержит текст «первое полугодие», следующая формула возвращает текст «Всего за первое полугодие»:
=СЦЕПИТЬ(«Всего за «;А5)
В начало страницы
В начало страницы
Функция ПОИСК() в MS EXCEL
Синтаксис функции
ПОИСК(искомый_текст;просматриваемая_строка;[нач_позиция])
Искомый_текст — текст, который требуется найти.
Просматриваемая_строка — текст, в которой ищется Искомый_текст.
Нач_позиция — позиция знака в просматриваемой_строке, с которой должен начинаться поиск. Если аргумент нач_позиция опущен, то предполагается значение 1.
В аргументе искомый_текст можно использовать подстановочные знаки — вопросительный знак (?) и звездочку (*). Вопросительный знак соответствует любому знаку; звездочка — любой последовательности знаков. Если нужно найти в тексте вопросительный знак или звездочку, следует поставить перед ними тильду (
Если искомый_текст не найден, возвращается значение ошибки #ЗНАЧ!
Функция ПОИСК() не учитывает РЕгиСТР букв. Для поиска с учетом регистра следует воспользоваться функцией НАЙТИ() .
Формула =ПОИСК(«к»;»Первый канал») вернет 8, т.к. буква к находится на 8-й позиции слева.
Пусть в ячейке А2 введена строка Первый канал — лучший. Формула =ПОИСК(СИМВОЛ(32);A2) вернет 7, т.к. символ пробела (код 32) находится на 7-й позиции.
Формула =ПОИСК(«#. #»;»Артикул #123# ID») будет искать в строке «Артикул #123# ID» последовательность из 5 символов, которая начинается и заканчивается на знак #.
Чтобы найти позицию второго вхождения буквы «а» в строке «мама мыла раму» используйте формулу =ПОИСК(«а»;»мама мыла раму»;ПОИСК(«а»;»мама мыла раму»)+1). Чтобы определить есть ли третье вхождение буквы «м» в строке «мама мыла раму» используйте формулу =ЕСЛИ(ДЛСТР(ПОДСТАВИТЬ(«мама мыла раму»;»м»;»»;3))=ДЛСТР(«мама мыла раму»);»Нет третьего вхождения м»;»Есть третье вхождение м»)
Формула =ПОИСК(«клад?»;»докладная») вернет 3, т.е. в слове «докладная» содержится слово из 5 букв, первые 4 из которых клад (начиная с третьей буквы слова докладная).
Функция НАЙТИ() vs ПОИСК()
Функция НАЙТИ() учитывает РЕгиСТР букв и не допускает использование подстановочных знаков. Для поиска без учета регистра, а также для поиска с использованием подстановочных знаков пользуйтесь функцией ПОИСК() .
Связь с функциями ЛЕВСИМВ() , ПРАВСИМВ() и ПСТР()
Функция ПОИСК() может быть использована совместно с функциями ЛЕВСИМВ() , ПРАВСИМВ() и ПСТР() .
Например, в ячейке А2 содержится фамилия и имя «Иванов Иван», то формула =ЛЕВСИМВ(A2;ПОИСК(СИМВОЛ(32);A2)-1) извлечет фамилию, а =ПРАВСИМВ(A2;ДЛСТР(A2)-ПОИСК(СИМВОЛ(32);A2)) — имя. Если между именем и фамилией содержится более одного пробела, то для работоспособности вышеупомянутых формул используйте функцию СЖПРОБЕЛЫ() .
На чтение 7 мин. Просмотров 29.7k.
Содержание
- Получить первое не пустое значение в списке
- Получить первое текстовое значение в списке
- Получить первое текстовое значение с ГПР
- Получить позицию последнего совпадения
- Получить последнее совпадение содержимого ячейки
- Получить n-е совпадение
- Получить n-ое совпадение с ИНДЕКС/ПОИСКПОЗ
- Получить n-ое совпадение с ВПР
- Если ячейка содержит одну из многих вещей
- Поиск первой ошибки
- Поиск следующего наибольшего значения
- Несколько совпадений в списке, разделенных запятой
- Частичное совпадение чисел с шаблоном
- Частичное совпадение с ВПР
- Положение первого частичного совпадения
Получить первое не пустое значение в списке
{ = ИНДЕКС( диапазон ; ПОИСКПОЗ( ЛОЖЬ; ЕПУСТО ( диапазон ); 0 )) }
Если вам нужно получить первое не пустое значение (текст или число) в диапазоне в одной колонке вы можете использовать формулу массива на основе функций ИНДЕКС, ПОИСКПОЗ и ЕПУСТО.
В данном примере мы используем эту формулу:
{ = ИНДЕКС( B3: B11; ПОИСКПОЗ( ЛОЖЬ; ЕПУСТО ( B3: B11 ); 0 )) }
Таким образом, суть проблемы заключается в следующем: мы хотим получить первую не пустую ячейку, но для этого нет конкретной формулы в Excel. Мы могли бы использовать ВПР с шаблоном *, но это будет работать только для текста, а не для чисел.
Таким образом, нам нужно строить функциональные возможности для нужных нам формул. Способ сделать это состоит в использовании функции массива, которая «тестирует» ячейки и возвращает массив истина/ложь значения, которые мы можем сопрягать с ПОИСКПОЗ.
Работая изнутри, ЕПУСТО оценивает ячейки в диапазоне В3: В11 и возвращает результат и массив, который выглядит следующим образом:
{ИСТИНА; ЛОЖЬ; ИСТИНА; ЛОЖЬ; ЛОЖЬ; ИСТИНА; ИСТИНА; ИСТИНА; ИСТИНА}
Каждая ЛОЖЬ представляет собой ячейку в диапазоне, который не является пустой.
Далее, ПОИСКПОЗ ищет ЛОЖЬ внутри массива и возвращает позицию первого наденного совпадения, в этом случае 2. На данный момент, формула в примере теперь выглядит следующим образом:
{ = ИНДЕКС( B3: B11; 2; 0 )) }
И, наконец, функция ИНДЕКС выводит значение в положении 2 в массиве, в этом случае число 10.
Получить первое текстовое значение в списке
= ВПР ( «*»; диапазон; 1; ЛОЖЬ)
Если вам нужно получить первое текстовое значение в списке (диапазон один столбец), вы можете использовать функцию ВПР, чтобы установить точное соответствие, с шаблонным символом для поиска.
В данном примере формула в D7 является:
= ВПР ( «*» ; B5: B11 ; 1 ; ЛОЖЬ)
Групповой символ звездочка (*) соответствует любому текстовому значению.
Получить первое текстовое значение с ГПР
= ГПР ( «*»; диапазон; 1; ЛОЖЬ)
Для поиска и получения первого текстового значения во всем диапазоне столбцов, вы можете использовать функцию ГПР с групповым символом. В примере формула в F5 является:
= ГПР ( «*»; С5: Е5; 1; 0 )
Значение поиска является «*», групповым символом, который соответствует одному или более текстовому значению.
Получить позицию последнего совпадения
{ = МАКС( ЕСЛИ ( Величины = знач ; СТРОКА(величина) — СТРОКА(ИНДЕКС( Величины; 1 ; 1 )) + 1 )) }
Для того, чтобы получить позицию последнего совпадения (т.е. последнего вхождения) от значения поиска, вы можете использовать формулу, основанную на ЕСЛИ, СТРОКА, ИНДЕКС, ПОИСКПОЗ и MAКС функций.
В примере формула в G6:
=МАКС(ЕСЛИ(B4:B11=G5;СТРОКА(B4:B11)-СТРОКА(ИНДЕКС(B4:B11;1;1))+1))
Суть этой формулы состоит в том, что мы строим список номеров строк для данного диапазона, соответствующие по значению, а затем используем функцию MAКС, чтобы получить наибольшее количество строк, что соответствует последнему значению соответствия.
Получить последнее совпадение содержимого ячейки
= ПРОСМОТР( 2 ; 1 / ПОИСК ( вещи ; А1 ); вещи )
Чтобы проверить ячейку для одной из нескольких вещей, и вернуть последнее совпадение, найденное в списке, вы можете использовать формулу, основанную на ПРОСМОТР и ПОИСК функций. В случае нескольких найденных совпадений, формула вернет последнее совпадение из списка «вещей».
В примере формула в С5:
=ПРОСМОТР(2;1/ПОИСК($E$4:$E$7;B4);$E$4:$E$7)
Получить n-е совпадение
= НАИМЕНЬШИЙ( ЕСЛИ( логический тест; СТРОКА( список ) — МИН( СТРОКА( список )) + 1 ); n )
Для того, чтобы получить позицию n-го совпадения (например, второе значение соответствия заданному, третье значение соответствия и т.д.), вы можете использовать формулу, основанную на функции НАИМЕНЬШИЙ.
= НАИМЕНЬШИЙ( ЕСЛИ( список = E5 ; СТРОКА( список ) — МИН( СТРОКА( список )) + 1 ); F5 )
Эта формула возвращает позицию второго появления «красных» в списке.
Сутью этой формулы является функция НАИМЕНЬШИЙ, которая просто возвращает n-е наименьшее значение в списке значений, которое соответствует номеру строки. Номера строк были «отфильтрованы» функцией ЕСЛИ, которая применяет логику для совпадения.
Получить n-ое совпадение с ИНДЕКС/ПОИСКПОЗ
{ = ИНДЕКС( массив; НАИМЕНЬШИЙ( ЕСЛИ( величины = знач ; СТРОКА ( величины ) — СТРОКА ( ИНДЕКС( величины; 1 ; 1 )) + 1 ); n-й )) }
Чтобы получить n-ое совпадение, используя ИНДЕКС и ПОИСКПОЗ, вы можете использовать формулу массива с функциями ЕСЛИ и НАИМЕНЬШИЙ, чтобы выяснить номер строки совпадения.
Получить n-ое совпадение с ВПР
= ВПР( id_формулы; стол; 4; 0 )
Чтобы получить n-ое совпадение с ВПР, вам необходимо добавить вспомогательный столбец в таблицу , которая строит уникальный идентификатор , который включает счетчик.
Эта формула зависит от вспомогательного столбца, который добавляется в качестве первого столбца таблицы исходных данных. Вспомогательный столбец содержит формулу, которая строит уникальное значение взгляда вверх от существующего идентификатора и счетчика. Счетчик подсчитывает сколько раз уникальный идентификатор появился в таблице данных.
В примере, формула ячейки J6 вспомогательного столбца выглядит следующим образом:
=ВПР(J3&»-«&I6;B4:G11;4;0)
Если ячейка содержит одну из многих вещей
{ = ИНДЕКС( результаты ;ПОИСКПОЗ( ИСТИНА ; ЕЧИСЛО( ПОИСК( вещи ; A1 )); 0 )) }
Чтобы проверить ячейку для одной из нескольких вещей, и вернуть пользовательский результат для первого найденного совпадения, вы можете использовать формулу ИНДЕКС/ПОИСКПОЗ, основанную на функции поиска.
{ = ИНДЕКС( результаты ; ПОИСКПОЗ( ИСТИНА ; ЕЧИСЛО( ПОИСК ( вещи ; B5 )); 0 )) }
Эта формула использует два названных диапазона: E5: E8 называется «вещи» и F5: F8 называется «Результаты». Убедитесь, что вы используете диапазоны имен с одинаковыми именами (на основе ваших данных). Если вы не хотите использовать именованные диапазоны, используйте абсолютные ссылки вместо этого.
Поиск первой ошибки
{ = ПОИСКПОЗ( ИСТИНА ; ЕОШИБКА(диап ); 0 ) }
Если вам нужно найти первую ошибку в диапазоне ячеек, вы можете использовать формулу массива, основанную на ПОИСКПОЗ и ЕОШИБКА функциях.
В приведенном примере формула:
{ = ПОИСКПОЗ( ИСТИНА ; ЕОШИБКА( B4: B11 ); 0 ) }
Работая изнутри, функция ЕОШИБКА возвращает значение ИСТИНА, если значение является признанной ошибкой, и ЛОЖЬ, если нет.
Когда дается диапазон ячеек (массив ячеек) функция ЕОШИБКА будет возвращать массив истина/ложь значений. В примере, это результирующий массив выглядит следующим образом:
{ЛОЖЬ; ЛОЖЬ; ЛОЖЬ; ЛОЖЬ; ЛОЖЬ; ИСТИНА; ЛОЖЬ; ЛОЖЬ}
Обратите внимание, что 6-е значение (что соответствует 6-й ячейке в диапазоне) истинно, так как ячейка В9 содержит #Н/A.
Поиск следующего наибольшего значения
=ИНДЕКС ( данные; ПОИСКПОЗ( поиск ; значения ) + 1 )
Для того, чтобы найти «следующее наибольшее» значение в справочной таблице, можно использовать формулу, основанную на ИНДЕКС и ПОИСКПОЗ. В примере формула в F6 является:
=ИНДЕКС(C5:C9;ПОИСКПОЗ(F4;B5:B9)+1)
Несколько совпадений в списке, разделенных запятой
{ = ОБЪЕДИНИТЬ ( «;» ; ИСТИНА ; ЕСЛИ( диапазон1 = E5 ; диапазон2 ; «» )) }
Для поиска и извлечения нескольких совпадений, разделенных запятыми (в одной ячейке), вы можете использовать функцию ЕСЛИ с функцией ОБЪЕДИНИТЬ.
{ = ОБЪЕДИНИТЬ( «;» ; ИСТИНА ; ЕСЛИ( группа = E5 ; имя ; «» )) }
Эта формула использует «имя» — именованный диапазон (B5: B11) и «группа» — (C5: C11).
Частичное совпадение чисел с шаблоном
{ = ПОИСКПОЗ( «*» & номер & «*» ; ТЕКСТ( диапазон ; «0» ); 0 ) }
Для того, чтобы выполнить частичное совпадение (подстроки) против чисел, вы можете использовать формулу массива, основанную на ПОИСКПОЗ и ТЕКСТ.
Excel поддерживает символы подстановки «*» и «?». Тем не менее, если вы используете специальные символы с номером, вы будете преобразовывать числовое значение в текстовое значение. Другими словами, «*» & 99 & «*» = «* 99 *» (текстовая строка).
Если попытаться найти текстовое значение в диапазоне чисел, совпадение завершится неудачно.
Решение
Одно из решений заключается в преобразовании чисел в диапазоне поиска для текстовых значений, а затем сделать нормальный поиск с ПОИСКПОЗ, ВПР и т.д.
Другой вариант
Другой способ, чтобы преобразовать числа в текст, чтобы сцепить пустую строку. Эта формула работает так же, как выше формуле:
= ПОИСКПОЗ ( «*» & Е5 & «*» ; В5: В10 & «» ; 0 )
Частичное совпадение с ВПР
Если вы хотите получить информацию из таблицы на основе частичного совпадения, вы можете сделать это с помощью ВПР в режиме точного соответствия, и групповые символы.
В примере формула ВПР выглядит следующим образом:
=ВПР($H$2&»*»;$B$3:$E$12;2;0)
В этой формуле, значение представляет собой именованный диапазон, который относится к Н2, а также данные , представляет собой именованный диапазон , который относится к B3: E102. Без названных диапазонов, формула может быть записана следующим образом:
Положение первого частичного совпадения
= ПОИСКПОЗ ( «* текст *» ; диапазон; 0 )
Для того, чтобы получить позицию первого частичного совпадения (то есть ячейку, которая содержит текст, который вы ищете), вы можете использовать функцию ПОИСКПОЗ со специальными символами.
В примере формула в Е7:
=ПОИСКПОЗ(«*»&E6&»*»;B5:B10;0)
Функция ПОИСКПОЗ возвращает позицию или «индекс» в первом совпадении на основании значения поиска в диапазоне.
ПОИСКПОЗ поддерживает подстановочное согласование со звездочкой «*» (один или несколько символов) или знаком вопроса «?» (один символ), но только тогда, когда третий аргумент, тип_сопоставления, установлен в ЛОЖЬ или ноль.
- Что делает функция ПОИСК?
- Синтаксис
- Форматирование
- Поиск символа в ячейке
- Извлечь первое слово
- Другие примеры использования
- Функция ПОИСК в формуле массива
Что делает функция ПОИСК?
Эта функция аналогична функции НАЙТИ и так же ищет подстроку в строке. Когда искомое найдено, отображается его позиция в тексте в виде числа.
Отличие от функции НАЙТИ в том, что ПОИСК не принимает в расчет регистр текста. Как искомого, так и того, в котором мы ищем. Также она поддерживает подстановочные операторы.
У обеих функций есть процедура-аналог Найти и Заменить – как у процедуры, у нее есть свои преимущества и недостатки.
Синтаксис
=ПОИСК(ИскомыйТекст;СтрокаВКоторойИщем;[СтартоваяПозиция])
- ИскомыйТекст — символ или сочетание, которое ищем
- СтрокаВКоторойИщем — ячейка, текстовое значение или любое возвращаемое другой функцией выражение.
- Стартовая позиция — опциональный параметр, при отсутствии поиск происходит с первого символа
Если текст содержит более одного вхождения, возвращается позиция первого.
Третий (опциональный) параметр используется для поиска с определенной позиции в тексте и по умолчанию равен 1.
Если искомое не найдено в тексте, функция возвращает ошибку #ЗНАЧ.
Форматирование
При поиске дат функция ПОИСК, как и все текстовые функции, воспринимает их как числа, поэтому для корректного поиска может понадобиться функция ТЕКСТ.
При этом логические значения ИСТИНА и ЛОЖЬ конвертируются в текст, соответствующий их написанию.
Поиск символа в ячейке
Наиболее простой пример использования функции – осуществление поиска определенного символа в ячейке.
Логика проста – если поиск позиции символа не возвращает ошибку, значит, символ в ячейке присутствует:
=НЕ(ЕОШ(ПОИСК(паттерн;текст)))
Извлечь первое слово
В этом простейшем примере извлекаем первое слово из ячейки с помощью комбинации — функция ЛЕВСИМВ + функция ПОИСК. Поскольку пробел — регистронезависимый символ, для этого случая можно использовать и функцию НАЙТИ.
Таблица выше была использована для извлечения имени из строки с именем и фамилией.
- ПОИСК возвращает позицию пробела между именем и фамилией.
- Длина имени вычисляется как позиция пробела минус 1.
- Функция ЛЕВСИМВ извлекает имя на основе его длины.
Другие примеры использования
Найти первую цифру в ячейке:
=МИН(ЕСЛИОШИБКА(ПОИСК({0:9:8:7:6:5:4:3:2:1};A1);1000))
Найти первую цифру в ячейке и вернуть все, что перед ней:
=ЛЕВСИМВ(A1,МИН(ЕСЛИОШИБКА(ПОИСК({0:9:8:7:6:5:4:3:2:1};A1);1000))-1)
Узнать, содержит ли ячейка латиницу. Формула вернет «ИСТИНА» или «ЛОЖЬ»:
=СЧЁТ(ПОИСК({"a":"b":"c":"d":"e":"f":"g":"h":"i":"j":"k":"l":"m":"n":"o":"p":"q":"r":"s":"t":"u":"v":"w":"x":"y":"z"};A1))>0
Найти кириллицу в тексте аналогичным путем:
=СЧЁТ(ПОИСК({"а":"б":"в":"г":"д":"е":"ё":"ж":"з":"и":"й":"к":"л":"м":"н":"о":"п":"р":"с":"т":"у":"ф":"х":"ц":"ч":"ш":"щ":"ъ":"ы":"ь":"э":"ю":"я"};A1))>0
Функция ПОИСК в формуле массива
Примеры выше, где буквы перечислены явно в строковом массиве, занимает довольно много места. Буквы при этом идут подряд, что наводит на мысль, что их можно как-то иначе выразить как диапазон.
И действительно, это возможно с помощью комбинации с функциями СТРОКА и ПОИСК:
{=СЧЁТ(ПОИСК(СИМВОЛ(СТРОКА(65:90));A1))>0}
Отличие этой формулы массива от предыдущих — ее нужно вводить без фигурных скобок, они появятся при вводе формулы сочетанием Ctrl+Shift+Enter (вместо обычного Enter). В формуле выше, где явно прописаны все буквы, фигурные скобки вводятся вручную — это явное указание строкового массива.
Что происходит в этой формуле?
- Функция СТРОКА с численным аргументом “65:90” возвращает массив чисел с 65 по 90 включительно. Как раз в этом диапазоне в таблице ASCII находятся все символы латиницы;
- Функция СИМВОЛ возвращает для каждого числового значения в этом массиве его символ, таким образом создавая массив латинских символов;
- Функция ПОИСК производит поиск каждого из этих символов в строке и возвращает либо число, либо ошибку, таким образом создавая массив чисел и ошибок
- Функция СЧЁТ считает числовые значения в полученном массиве. Если результат больше нуля, значит, хотя бы один символ латиницы был найден. Если нет (все поиски вернули ошибку), значит, не был
Аналогичная формула для кириллицы:
{=СЧЁТ(ПОИСК(СИМВОЛ(СТРОКА(192:223));A1))>0}
Подробнее о поиске и извлечении кириллицы и латиницы в Excel можно почитать тут:
Найти латиницу или кириллицу в тексте
Есть еще множество комбинаций функции ПОИСК с другими функциями Excel, смотрите разделы:
Функция ИЛИ
Функция И
Функция ЗНАЧЕН
Удалить первое слово в ячейке Excel
Смотрите также по теме:
ОБНАРУЖИТЬ (функционал надстройки !SEMTools)
Регулярные выражения в Excel
Найти определенные символы в Excel
Найти слова в ячейках
Найти числа в текстовых ячейках
Понравилась статья? Поддержите ее автора!
Набор инструментов !SEMTools поможет решить множество задач без ввода сложных формул и сэкономит ваше время. И вам полезно, и автору приятно!