Содержание
- Нумерация строк по условию в excel
- Автоматическая нумерация строк в Excel: 3 способа
- Метод 1: нумерация после заполнения первых строк
- Метод 2: оператор СТРОКА
- Метод 3: применение прогрессии
- Заключение
- 5 интересных способов как происходит нумерация строк в Excel
- Нумерация строк по условию в excel
- Функция ВПР
- Функция ГПР
- Функция СТРОКА
- Функция СТОЛБЕЦ
- Функция АДРЕС
- Функция ДВССЫЛ
- Функция ЧСТРОК
- Функция ЧИСЛСТОЛБ
- Функция СМЕЩ
- Функция ПОИСКПОЗ
- Функция ПОИСКПОЗ в Excel
- Нумерация строк в EXCEL
- Используем формулы
- Используем клавишу CTRL
- Используем начало последовательности
- Использование инструмента Прогрессия
- Нумерация строк по условию в excel
- Функция ВПР
- Функция ГПР
- Функция СТРОКА
- Функция СТОЛБЕЦ
- Функция АДРЕС
- Функция ДВССЫЛ
- Функция ЧСТРОК
- Функция ЧИСЛСТОЛБ
- Функция СМЕЩ
- Функция ПОИСКПОЗ
- Функция ПОИСКПОЗ в Excel
Нумерация строк по условию в excel
Автоматическая нумерация строк в Excel: 3 способа
Во время работы в Excel нередко требуется нумерация строк в отдельном столбце. Сделать это можно, прописав порядковые номера в ручном режиме, другими словами, набрав их на клавиатуре. Однако при работе с большим объемом информации проставлять номера вручную – не слишком приятная и быстрая процедура, при которой, к тому же, могут быть допущены ошибки и опечатки. К счастью, Эксель позволяет автоматизировать этот процесс, и ниже мы рассмотрим, как именно это можно реализовать различными способами.
Метод 1: нумерация после заполнения первых строк
Данный метод, пожалуй, самый простой. При его реализации требуется лишь заполнить первые две строки столбца, после чего можно растянуть нумерацию на оставшиеся строки. Однако, он удобен только при работе с небольшими таблицами.
- Для начала, создаем новый столбец под нумерацию строк. В первой ячейке (не считая шапки) пишем цифру 1, затем переходим во вторую, в которой вводим цифру 2.
- Теперь нужно выделить эти две ячейки, после чего наводим курсор мыши на нижний правый угол выделенной области. Как только указатель изменит свой вид на крестик, зажав левую кнопку мыши тянем его до последней строки столбца.
- Отпускаем левую кнопку мыши, и порядковые номера строк сразу же появятся в строках, которые мы охватили при растягивании.
Метод 2: оператор СТРОКА
Данный метод для автоматической нумерации строк предполагает использование фукнции “СТРОКА”.
- Встаем в первую ячейку столбца, которой хотим присвоить порядковый номер 1. Затем пишем в ней следующую формулу: =СТРОКА(A1) .
- Как только мы щелкнем Enter, в выбранной ячейке появится порядковый номер. Осталось, аналогично первому методу, растянуть формулу на нижние строки. Но теперь нужно навести курсор мыши на нижний правый угол ячейки с формулой.
- Все готово, мы автоматически пронумеровали все строки таблицы, что и требовалось.
Вместо ручного ввода формулы можно воспользоваться Мастером функций.
- Также выделяем первую ячейку столбца, куда хотим вставить номер. Затем щелкаем кнопку “Вставить функцию” (слева от строки формул).
- Откроется окно Мастера функций. Кликаем по текущей категории функций и выбираем в открывшемся перечне “Ссылки и массивы”.
- Теперь из списка предложенных операторов выбираем функцию “СТРОКА”, после чего жмем OK.
- На экране появится окно с аргументами функции для заполнения. Кликаем по области ввода информации для параметра “Строка” и указываем адрес первой ячейки столбца, которой хотим присвоить номер. Адрес можно прописать вручную или просто кликнуть мышью по нужной ячейке. Далее кликаем OK.
- Нумер строки вставлен в выбранную ячейку. Как растянуть нумерацию на остальные строки мы рассмотрели выше.
Метод 3: применение прогрессии
Минусом первого и второго методов является то, что приходится растягивать номера на другие строки, что при больших размерах таблицы по вертикали не слишком удобно. Поэтому давайте рассмотрим еще один способ, который избавляет от необходимости выполнять такое действие.
- Указываем в первой ячейки столбца ее порядковый номер, равный цифре 1.
- Переключаемся во вкладку “Главная”, нажимаем кнопку “Заполнить” (раздел “Редактирование”) и в раскрывшемся перечне щелкаем по опции “Прогрессия…”.
- Перед нами появится окно с параметрами прогрессии, которые нужно настроить, после чего нажимаем OK.
- выбираем расположение “по столбцам”;
- тип указываем “арифметический”;
- в значении шага пишем цифру “1”;
- в поле “Предельное значение” указываем количество строк таблицы, которые нужно пронумеровать.
- Автоматическая нумерация строк выполнена, и мы получили требуемый результат.
Данный метод можно реализовать по-другому.
- Повторяем первый шаг, т.е. в первой ячейке столбца пишем цифру 1.
- Выделяем диапазон, включающий все ячейки, в которые мы хотим вставить номера.
- Снова открываем окно “Прогрессии”. Параметры автоматически выставлены согласно выделенному нами диапазону, поэтому нам остается только щелкнуть OK.
- И снова, благодаря этим несложным действиям мы получаем нумерацию строк в выбранном диапазоне.
Удобство такого метода в том, что не нужно считать и прописывать количество строк, в которые нужно вставить номера. А недостаток заключается в том, что как и в первом и втором методах, придется заранее выделить диапазон ячеек, что не так удобно при работе с большими таблицами.
Заключение
Нумерация строк может значительно упростить работу в Эксель при работе с большим объемом данных. Выполнить ее можно разными способами, начиная от ручного заполнения, заканчивая полностью автоматизированным процессом, который исключит любые возможные ошибки и опечатки.
5 интересных способов как происходит нумерация строк в Excel
Добрый день уважаемый друг!
В этой статье я хочу осветить ответ на вопрос: «Как делается быстрая нумерация строк в Excel?». Поскольку в MS Excel списки не редкость, а скорее основа основ, так как все данные для анализа берутся с ваших списков. А если есть список, было бы неплохо его пронумеровать, так как номер строки является неким ключом необходимый для дальнейшего анализа, а желательно чтобы производилась автоматическая нумерация списков.
На данный момент можно выделить 5 способов как происходит нумерация строк в Excel:
- Это когда вы вручную долго и муторно набираете, надо в каждую ячейку вбивать нужную вам циферку списка, если вы хотите использовать данный способ делайте в том случае когда в списке не более 10 пунктов;
- Этот способ заключается в простой протяжке ячейки, так производится автоматическая нумерация. Хорошо конечно, но когда вам прийдется вставлять дополнительные строки, нумерацию вам прийдется снова перетягивать на весь диапазон, аналогично созданию пользовательского списка. Всю процедуру протягивания необходимо производить при зажатой кнопке Ctrl;
- Третьим вариантом будет нумерация с помощью формулы «=А4+1», эта простая формула берет вышестоящее значение и прибавляет к нему 1. Как итог, получаем пронумерованный список любой длины всего за несколько секунд. Даже когда вам нужно добавить пару строк в диапазон списка, то простая протяжка формулы на месте вставки и всё прекрасно работает и радует глаз;
- Можно усовершенствовать формулу сделав так что вертикальная нумерация строк привязалась к горизонтальной и тогда ссылка станет абсолютной. Горизонтальную нумерацию делаем при помощи функции СТОЛБЕЦ, а вертикальную при помощи функции СТРОКА, в итоге формула списка приобретёт следующий вида: =СТРОКА() -СТРОКА($A$4);
- Ну и на закусочку можно поговорить о том как получается интеллектуальная нумерация. Для этого используем формулу следующего вида: =ЕСЛИ(ЕПУСТО(B4);»»;СЧЁТЗ($B$4:B4)). С формулы вы видите что логическая функция ЕСЛИ проверяет пустой или заполненный список. При пустом значении ячейка не заполняется, а вот при заполненной, функция СЧЁТЗ возвращает значение +1, увеличивая тем самым номер списка. Огромным преимуществом становится то, что при делении значения список сам перестраивается игнорируя пустые поля и у вас получается автоматическая нумерация в Excel.
Вот мы и рассмотрели способы как происходит автоматическая нумерация в Excel, надеюсь данная информация вам поможет и облегчит вашу работу в MS Excel. Совместно с нумерацией списков, очень удобно использовать закрепление области в Excel, что позволит усовершенствовать вашу работу. Если у вас есть дополнительная информация пишите в комментариях свои предложения. Ставьте лайки если статья вам понравилась!
Скачать пример можно здесь.
Не забудьте поблагодарить автора!
Деньгам по-пустому лежать не надлежит.
Александр Васильевич Суворов
Нумерация строк по условию в excel
В данной статье рассмотрены некоторые функции по работе со ссылками и массивами:
Функция ВПР
Вертикальное первое равенство. Ищет совпадение по ключу в первом столбце определенного диапазона и возвращает значение из указанного столбца этого диапазона в совпавшей с ключом строке.
Синтаксис: =ВПР(ключ; диапазон; номер_столбца; [интервальный_просмотр]), где
- ключ – обязательный аргумент. Искомое значение, для которого необходимо вернуть значение.
- диапазон – обязательный аргумент. Таблица, в которой необходимо найти значение по ключу. Первый столбец таблицы (диапазона) должен содержать значение совпадающее с ключом, иначе будет возвращена ошибка #Н/Д.
- номер_столбца – обязательный аргумент. Порядковый номер столбца в указанном диапазоне из которого необходимо возвратить значение в случае совпадения ключа.
- интервальный_просмотр – необязательный аргумент. Логическое значение указывающее тип просмотра:
- ЛОЖЬ – функция ищет точное совпадение по первому столбцу таблицы. Если возможно несколько совпадений, то возвращено будет самое первое. Если совпадение не найдено, то функция возвращает ошибку #Н/Д.
- ИСТИНА – функция ищет приблизительное совпадение. Является значением по умолчанию. Приблизительное совпадение означает, если не было найдено ни одного совпадения, то функция вернет значение предыдущего ключа. При этом предыдущим будет считаться тот ключ, который идет перед искомым согласно сортировке от меньшего к большему либо от А до Я. Поэтому, перед применением функции с данным интервальным просмотром, предварительно отсортируйте первый столбец таблицы по возрастанию, так как, если это не сделать, функция может вернуть неправильный результат. Когда найдено несколько совпадений, возвращается последнее из них.
Важно не путать, что номер столбца указывается не по индексу на листе, а по порядку в указанном диапазоне.
На изображении приведено 3 таблицы. Первая и вторая таблицы располагают исходными данными. Третья таблица собрана из первых двух.
В первой таблице приведены категории товара и расположение каждой категории.
Во второй категории имеется список всех товаров с указанием цен.
Третья таблица содержать часть товаров для которых необходимо определить цену и расположение.
Для цены необходимо использовать функцию ВПР с точным совпадением (интервальный просмотр ЛОЖЬ), так как данный параметр определен для всех товаров и не предусматривает использование цены другого товара, если вдруг она по случайности еще не определена.
Для определения расположения товара используется ВПР с приблизительным совпадением (интервальный просмотр ИСТИНА), так как распределение товара осуществляется по категориям. Из-за того, что наименование товара состоит из названия категории плюс дополнительный текст, по условиям сортировки от А до Я наименования товаров будут идти сразу после наименования категории, поэтому когда в таблице не обнаруживается совпадений с ключом подтягивается первое значение сверху.
В принципе, данный подход устраивал бы, если для товаров, для которых отсутствует категория, не подтягивалось расположение. Обратите внимание на товар «Лук Подмосковье». Для него определено расположение «Стелаж №2», хотя в первой таблице нет категории «Лук». Это происходит все по тем же причинам, когда функцией не обнаруживается равенств, то она определяет для значения значение меньшего самого близкого по сортировке ключа, а для «Лук Подмосковье» это категория «Картофель».
Он подобного эффекта можно избавиться путем определения категории из наименования товара используя текстовые функции ЛЕВСИМВ(C11;ПОИСК(» «;C11)-1), которые вернут все символы до первого пробела, а также изменить интервальный просмотр на точный.
Помимо всего описанного, функция ВПР позволяет применять для текстовых значений подстановочные символы – * (звездочка – любое количество любых символов) и ? (один любой символ). Например, для искомого значения «*» & «иван» & «*» могут подойти строки Иван, Иванов, диван и т.д.
Также данная функция может искать значения в массивах – =ВПР(1; ;2;ЛОЖЬ) – результат выполнения строка «Два».
Функция ГПР
Горизонтальное первое равенство. Ищет совпадение по ключу в первой строке определенного диапазона и возвращает значение из указанной строки этого диапазона в совпавшем с ключом столбце.
Синтаксис: =ГПР(ключ; диапазон; номер_строки; [интервальный_просмотр]).
Так как функция аналогична функции ВПР, за исключением того, что использует горизонтальные таблицы вместо вертикальных, то описания и примеры использования подходят и для ГПР с учетом упомянутых различий.
Функция СТРОКА
Определяет и возвращает номер строки указанной ссылкой ячейки.
Синтаксис: =СТРОКА([ссылка]), где аргумент «ссылка» не является обязательным. Если он опущен, но возвращается номер текущей строки.
=СТРОКА(D4) – результат 4.
=СТРОКА() – функция вернет номер строки, в которой она расположена.
Функция СТОЛБЕЦ
Возвращает номер столбца ячейки, указанной ссылкой.
Синтаксис: =СТОЛБЕЦ([ссылка]), где «ссылка» не обязательный аргумент. По умолчанию возвращается номер текущего столбца.
=СТОЛБЕЦ(C4) – формула вернет значение 3.
=СТОЛБЕЦ() – функция возвращает номер столбца, в котором расположена.
Функция АДРЕС
Возвращает текст, представляющий адрес ячейки, заданной номерами строки и столбца.
Синтаксис: =АДРЕС(строка; столбец; [тип_закрепления]; [стиль_ссылки]; [имя_листа]), где:
- Строка – обязательный аргумент. Число, представляющая номер строки, для которой необходимо вернуть адрес;
- Столбец – обязательный аргумент. Число, представляющее номер столбца целевой ячейки.
- тип_закрепления – необязательный аргумент. Число от 1 до 4, обозначающее закрепление индексов ссылки:
- 1 – значение по умолчанию, когда закреплены все индексы;
- 2 – закрепление индекса строки;
- 3 – закрепление индекса столбца;
- 4 – адрес без закреплений.
- стиль_ссылки – необязательный аргумент. Логическое значение:
- ИСТИНА – формат ссылок «A1»;
- ЛОЖЬ – формат ссылок «R1C1».
- имя_листа – необязательный аргумент. Строка, представляющая имя листа, который необходимо добавить к тексту адреса ячейки.
=АДРЕС(1;1) – возвращает $A$1.
=АДРЕС(1;1;4) – возвращает A1.
=АДРЕС(1;1;4;ЛОЖЬ) – результат R[1]C[1].
=АДРЕС(1;1;4;ЛОЖЬ;»Лист1″) – результат выполнения функции Лист1!R[1]C[1].
Функция ДВССЫЛ
Преобразует адрес ссылки, заданный текстовой строкой, в ссылку на данный адрес.
Синтаксис: =ДВССЫЛ(адрес_ссылки; [стиль_ссылки]), где
- адрес_ссылки – обязательный аргумент. Строка, представляющая адрес ссылки на ячейку или диапазон. Например, «C3», «R3C3» или «D8:D9».
- стиль_ссылки – необязательный аргумент. Логическое значение, определяющее стиль ссылки:
- ИСТИНА – стиль A1. Является значением по умолчанию;
- ЛОЖЬ – стиль R1C1.
=ДВССЫЛ(«a3») – возвращает ссылку на ячейку A3.
=ДВССЫЛ(«r3c3») – вернет ошибку #ССЫЛКА!, так как текст для ссылки в формате R1C1, а второй аргумент имеет значение по умолчанию.
=ДВССЫЛ(«r3c3»; ЛОЖЬ) – возвращает ссылку на ячейку C3.
=ДВССЫЛ(АДРЕС(СТРОКА(C3);СТОЛБЕЦ(C3))) – функция вернет аналогичный предыдущему примеру результат.
Вложение функции ДВССЫЛ со ссылкой на диапазон:
Функция ЧСТРОК
Возвращает число строк в указанном диапазоне или массиве.
Синтаксис: =ЧСТРОК(ссылка), где «ссылка» обязательный аргумент, являющийся ссылкой на ячейку, диапазон либо массив.
Пример использования:
=ЧСТРОК(D1:D8) – функция возвращает результат 8.
=ЧСТРОК( ) – функция определят, что в массиве 5 строк.
Функция ЧИСЛСТОЛБ
Возвращает число столбцов в указанном диапазоне или массиве.
Синтаксис: =ЧИСЛСТОЛБ(ссылка), где «ссылка» обязательный аргумент, являющийся ссылкой на ячейку, диапазон либо массив.
Пример использования:
=ЧИСЛСТОЛБ(A5:D5) – результат функции 4.
=ЧИСЛСТОЛБ( ) – функция определят, что в массиве 5 столбцов.
Функция СМЕЩ
Смещает ссылку на диапазон на указанное количество строк и столбцов, а также позволяет изменить его размерность.
Функция не передвигает и не изменяет самих ячеек, а только подменяет саму ссылку.
Синтаксис: =СМЕЩ(ссылка; смещ_по_строкам; смещ_по_столбцам; [высота]; [ширина]), где
- ссылка – обязательный аргумент.
Ссылка на ячейку либо диапазон, относительно которого необходимо произвести смещение.
Если в результате смещения диапазон стал выходить на пределы листа, то функция возвращает ошибку #ССЫЛКА!.
Для примера будем использовать вложение функции СМЕЩ в функцию СУММ.
Изначально ссылаемся на диапазон из 10 строк и 1 столбца, где все ячейки имеют значение 2. Таким образом получает результат выполнения формулы – 20.
Теперь сместим диапазон на один столбец влево, т.е. на -1.
Снова изменим ссылку, а именно расширим до 4 столбцов. После этого возвращаемая ссылка станет A3:D12. Результат на изображении.
Функция ПОИСКПОЗ
Возвращает позицию элемента, заданного по значению, в диапазоне либо массиве.
Синтаксис: =ПОИСКПОЗ(искомое_значение; массив; [тип_сопоставления]), где:
- искомое_значение – обязательный аргумент. Значение элемента, который необходимо найти в массиве.
- Массив – обязательный аргумент. Одномерный диапазон либо массив для поиска элемента.
- тип_сопоставления – необязательный аргумент. Число 1, 0 или -1, определяющее способ поиска элемента:
- 1 – значение по умолчанию. Если совпадений не найдено, то возвращается позиция ближайшего меньшего по значению к искомому элементу. Массив или диапазон должен быть отсортирован от меньшего к большему или от А до Я.
- 0 – функция ищет точное совпадение. Если не найдено, то возвращается ошибка #Н/Д.
- -1 – Если совпадений не найдено, то возвращается позиция ближайшего большего по значению к искомому элементу. Массив или диапазон должен быть отсортирован по убыванию.
Пример использования:
=ПОИСКПОЗ(«Г»; ) – функция возвращает результат 4.
Функция ПОИСКПОЗ в Excel
При этом регистр не учитывается.
=ПОИСКПОЗ(«е»; ; 1) – результат 5, т.к. элемента не найдено, поэтому возвращается ближайший меньший по значению элемент. Элементы массива записаны по возрастанию.
=ПОИСКПОЗ(«е»; ; 0) – возвращается ошибка, т.к. элемент не найден, а тип сопоставления указан на точное совпадение.
=ПОИСКПОЗ(«в»; ; -1) – результат 3.
=ПОИСКПОЗ(«д»; ; -1) – элемент не найден, хотя присутствует в массиве. Функция возвращает неверный результат, так как последний аргумент принимает значение -1, а элементы НЕ расположены по убыванию.
Для текстовых значений функция допускает использование подстановочных символов «*» и «?».
Если материалы office-menu.ru Вам помогли, то поддержите, пожалуйста, проект, чтобы мы могли развивать его дальше.
У Вас недостаточно прав для комментирования.
Нумерация строк в EXCEL
Используем различные подходы для нумерации строк.
Используем формулы
Пусть в ячейке A2 введено значение 1 (номер первой строки). В следующую строку таблицы, в ячейку А3 , вводим формулу =А2+1 и копируем ее в ячейки ниже.
Так как в формуле мы сослались на ячейку выше с помощью относительной ссылки , то EXCEL при копировании вниз модифицирует вышеуказанную формулу в =А3+1 , затем в =А4+1 и т.д., тем самым формируя числовую последовательность 2, 3, 4, .
Другим вариантом является использование формулы =СТРОКА()-СТРОКА($A$1) . В ячейке А1 должен находиться заголовок столбца.
Для чрезстрочной нумерации используйте формулу (см. файл примера ) =ЕСЛИ(ЕЧЁТН(СТРОКА());»»;A7+1)
Используем клавишу CTRL
Пусть, как и в предыдущем примере, в ячейку A2 введено значение 1 . Выделим ячейку A2 . Удерживая клавишу CTRL , скопируем Маркером заполнения (при этом над курсором появится маленький плюсик), значение из A 2 в ячейки ниже. Получим последовательность чисел 1, 2, 3, 4 …
ВНИМАНИЕ! Если на листе часть строк скрыта с помощью фильтра , то этот подход и остальные, приведенные ниже, работать не будут. Чтобы разрешить нумерацию строк с использованием клавиши CTRL , выделите любую ячейку с заголовком фильтра и дважды нажмите CTRL + SHIFT + L (сбросьте фильтр).
Используем начало последовательности
Если начало последовательности уже задано (т.е. задан первый элемент и шаг последовательности), то пронумеровать строки можно следующим образом :
- пусть в ячейке А2 введено значение 1 , а в ячейке А3 значение 2 ;
- выделяем ячейки A2 и A3 ;
- беремся за правый нижний угол и Маркером заполнения протягиваем вниз.
Получаем результат как в предыдущем случае. Если в ячейке А3 введено значение 3 , т.е. задан шаг последовательности равный 2, то мы получим последовательность нечетных чисел.
Использование инструмента Прогрессия
Воспользуемся стандартным средством EXCEL для создания прогрессий, в то числе и арифметических.
- вводим в ячейку А2 значение 1 ;
- выделяем диапазон A2:А6 , в котором будут содержаться номера строк;
- вызываем инструмент Прогрессия ( Главная/ Редактирование/ Заполнить/ Прогрессия. ), в появившемся окне нажимаем ОК.
Нумерация строк по условию в excel
В данной статье рассмотрены некоторые функции по работе со ссылками и массивами:
Функция ВПР
Вертикальное первое равенство. Ищет совпадение по ключу в первом столбце определенного диапазона и возвращает значение из указанного столбца этого диапазона в совпавшей с ключом строке.
Синтаксис: =ВПР(ключ; диапазон; номер_столбца; [интервальный_просмотр]), где
- ключ – обязательный аргумент. Искомое значение, для которого необходимо вернуть значение.
- диапазон – обязательный аргумент. Таблица, в которой необходимо найти значение по ключу. Первый столбец таблицы (диапазона) должен содержать значение совпадающее с ключом, иначе будет возвращена ошибка #Н/Д.
- номер_столбца – обязательный аргумент. Порядковый номер столбца в указанном диапазоне из которого необходимо возвратить значение в случае совпадения ключа.
- интервальный_просмотр – необязательный аргумент. Логическое значение указывающее тип просмотра:
- ЛОЖЬ – функция ищет точное совпадение по первому столбцу таблицы. Если возможно несколько совпадений, то возвращено будет самое первое. Если совпадение не найдено, то функция возвращает ошибку #Н/Д.
- ИСТИНА – функция ищет приблизительное совпадение. Является значением по умолчанию. Приблизительное совпадение означает, если не было найдено ни одного совпадения, то функция вернет значение предыдущего ключа. При этом предыдущим будет считаться тот ключ, который идет перед искомым согласно сортировке от меньшего к большему либо от А до Я. Поэтому, перед применением функции с данным интервальным просмотром, предварительно отсортируйте первый столбец таблицы по возрастанию, так как, если это не сделать, функция может вернуть неправильный результат. Когда найдено несколько совпадений, возвращается последнее из них.
Важно не путать, что номер столбца указывается не по индексу на листе, а по порядку в указанном диапазоне.
На изображении приведено 3 таблицы. Первая и вторая таблицы располагают исходными данными. Третья таблица собрана из первых двух.
В первой таблице приведены категории товара и расположение каждой категории.
Во второй категории имеется список всех товаров с указанием цен.
Третья таблица содержать часть товаров для которых необходимо определить цену и расположение.
Для цены необходимо использовать функцию ВПР с точным совпадением (интервальный просмотр ЛОЖЬ), так как данный параметр определен для всех товаров и не предусматривает использование цены другого товара, если вдруг она по случайности еще не определена.
Для определения расположения товара используется ВПР с приблизительным совпадением (интервальный просмотр ИСТИНА), так как распределение товара осуществляется по категориям. Из-за того, что наименование товара состоит из названия категории плюс дополнительный текст, по условиям сортировки от А до Я наименования товаров будут идти сразу после наименования категории, поэтому когда в таблице не обнаруживается совпадений с ключом подтягивается первое значение сверху.
В принципе, данный подход устраивал бы, если для товаров, для которых отсутствует категория, не подтягивалось расположение. Обратите внимание на товар «Лук Подмосковье». Для него определено расположение «Стелаж №2», хотя в первой таблице нет категории «Лук». Это происходит все по тем же причинам, когда функцией не обнаруживается равенств, то она определяет для значения значение меньшего самого близкого по сортировке ключа, а для «Лук Подмосковье» это категория «Картофель».
Он подобного эффекта можно избавиться путем определения категории из наименования товара используя текстовые функции ЛЕВСИМВ(C11;ПОИСК(» «;C11)-1), которые вернут все символы до первого пробела, а также изменить интервальный просмотр на точный.
Помимо всего описанного, функция ВПР позволяет применять для текстовых значений подстановочные символы – * (звездочка – любое количество любых символов) и ? (один любой символ). Например, для искомого значения «*» & «иван» & «*» могут подойти строки Иван, Иванов, диван и т.д.
Также данная функция может искать значения в массивах – =ВПР(1; ;2;ЛОЖЬ) – результат выполнения строка «Два».
Функция ГПР
Горизонтальное первое равенство. Ищет совпадение по ключу в первой строке определенного диапазона и возвращает значение из указанной строки этого диапазона в совпавшем с ключом столбце.
Синтаксис: =ГПР(ключ; диапазон; номер_строки; [интервальный_просмотр]).
Так как функция аналогична функции ВПР, за исключением того, что использует горизонтальные таблицы вместо вертикальных, то описания и примеры использования подходят и для ГПР с учетом упомянутых различий.
Функция СТРОКА
Определяет и возвращает номер строки указанной ссылкой ячейки.
Синтаксис: =СТРОКА([ссылка]), где аргумент «ссылка» не является обязательным. Если он опущен, но возвращается номер текущей строки.
=СТРОКА(D4) – результат 4.
=СТРОКА() – функция вернет номер строки, в которой она расположена.
Функция СТОЛБЕЦ
Возвращает номер столбца ячейки, указанной ссылкой.
Синтаксис: =СТОЛБЕЦ([ссылка]), где «ссылка» не обязательный аргумент. По умолчанию возвращается номер текущего столбца.
=СТОЛБЕЦ(C4) – формула вернет значение 3.
=СТОЛБЕЦ() – функция возвращает номер столбца, в котором расположена.
Функция АДРЕС
Возвращает текст, представляющий адрес ячейки, заданной номерами строки и столбца.
Синтаксис: =АДРЕС(строка; столбец; [тип_закрепления]; [стиль_ссылки]; [имя_листа]), где:
- Строка – обязательный аргумент. Число, представляющая номер строки, для которой необходимо вернуть адрес;
- Столбец – обязательный аргумент. Число, представляющее номер столбца целевой ячейки.
- тип_закрепления – необязательный аргумент. Число от 1 до 4, обозначающее закрепление индексов ссылки:
- 1 – значение по умолчанию, когда закреплены все индексы;
- 2 – закрепление индекса строки;
- 3 – закрепление индекса столбца;
- 4 – адрес без закреплений.
- стиль_ссылки – необязательный аргумент. Логическое значение:
- ИСТИНА – формат ссылок «A1»;
- ЛОЖЬ – формат ссылок «R1C1».
- имя_листа – необязательный аргумент. Строка, представляющая имя листа, который необходимо добавить к тексту адреса ячейки.
=АДРЕС(1;1) – возвращает $A$1.
=АДРЕС(1;1;4) – возвращает A1.
=АДРЕС(1;1;4;ЛОЖЬ) – результат R[1]C[1].
=АДРЕС(1;1;4;ЛОЖЬ;»Лист1″) – результат выполнения функции Лист1!R[1]C[1].
Функция ДВССЫЛ
Преобразует адрес ссылки, заданный текстовой строкой, в ссылку на данный адрес.
Синтаксис: =ДВССЫЛ(адрес_ссылки; [стиль_ссылки]), где
- адрес_ссылки – обязательный аргумент. Строка, представляющая адрес ссылки на ячейку или диапазон. Например, «C3», «R3C3» или «D8:D9».
- стиль_ссылки – необязательный аргумент. Логическое значение, определяющее стиль ссылки:
- ИСТИНА – стиль A1. Является значением по умолчанию;
- ЛОЖЬ – стиль R1C1.
=ДВССЫЛ(«a3») – возвращает ссылку на ячейку A3.
=ДВССЫЛ(«r3c3») – вернет ошибку #ССЫЛКА!, так как текст для ссылки в формате R1C1, а второй аргумент имеет значение по умолчанию.
=ДВССЫЛ(«r3c3»; ЛОЖЬ) – возвращает ссылку на ячейку C3.
=ДВССЫЛ(АДРЕС(СТРОКА(C3);СТОЛБЕЦ(C3))) – функция вернет аналогичный предыдущему примеру результат.
Вложение функции ДВССЫЛ со ссылкой на диапазон:
Функция ЧСТРОК
Возвращает число строк в указанном диапазоне или массиве.
Синтаксис: =ЧСТРОК(ссылка), где «ссылка» обязательный аргумент, являющийся ссылкой на ячейку, диапазон либо массив.
Пример использования:
=ЧСТРОК(D1:D8) – функция возвращает результат 8.
=ЧСТРОК( ) – функция определят, что в массиве 5 строк.
Функция ЧИСЛСТОЛБ
Возвращает число столбцов в указанном диапазоне или массиве.
Синтаксис: =ЧИСЛСТОЛБ(ссылка), где «ссылка» обязательный аргумент, являющийся ссылкой на ячейку, диапазон либо массив.
Пример использования:
=ЧИСЛСТОЛБ(A5:D5) – результат функции 4.
=ЧИСЛСТОЛБ( ) – функция определят, что в массиве 5 столбцов.
Функция СМЕЩ
Смещает ссылку на диапазон на указанное количество строк и столбцов, а также позволяет изменить его размерность.
Функция не передвигает и не изменяет самих ячеек, а только подменяет саму ссылку.
Синтаксис: =СМЕЩ(ссылка; смещ_по_строкам; смещ_по_столбцам; [высота]; [ширина]), где
- ссылка – обязательный аргумент.
Ссылка на ячейку либо диапазон, относительно которого необходимо произвести смещение.
Если в результате смещения диапазон стал выходить на пределы листа, то функция возвращает ошибку #ССЫЛКА!.
Для примера будем использовать вложение функции СМЕЩ в функцию СУММ.
Изначально ссылаемся на диапазон из 10 строк и 1 столбца, где все ячейки имеют значение 2. Таким образом получает результат выполнения формулы – 20.
Теперь сместим диапазон на один столбец влево, т.е. на -1.
Снова изменим ссылку, а именно расширим до 4 столбцов. После этого возвращаемая ссылка станет A3:D12. Результат на изображении.
Функция ПОИСКПОЗ
Возвращает позицию элемента, заданного по значению, в диапазоне либо массиве.
Синтаксис: =ПОИСКПОЗ(искомое_значение; массив; [тип_сопоставления]), где:
- искомое_значение – обязательный аргумент. Значение элемента, который необходимо найти в массиве.
- Массив – обязательный аргумент. Одномерный диапазон либо массив для поиска элемента.
- тип_сопоставления – необязательный аргумент. Число 1, 0 или -1, определяющее способ поиска элемента:
- 1 – значение по умолчанию. Если совпадений не найдено, то возвращается позиция ближайшего меньшего по значению к искомому элементу. Массив или диапазон должен быть отсортирован от меньшего к большему или от А до Я.
- 0 – функция ищет точное совпадение. Если не найдено, то возвращается ошибка #Н/Д.
- -1 – Если совпадений не найдено, то возвращается позиция ближайшего большего по значению к искомому элементу. Массив или диапазон должен быть отсортирован по убыванию.
Пример использования:
=ПОИСКПОЗ(«Г»; ) – функция возвращает результат 4.
Функция ПОИСКПОЗ в Excel
При этом регистр не учитывается.
=ПОИСКПОЗ(«е»; ; 1) – результат 5, т.к. элемента не найдено, поэтому возвращается ближайший меньший по значению элемент. Элементы массива записаны по возрастанию.
=ПОИСКПОЗ(«е»; ; 0) – возвращается ошибка, т.к. элемент не найден, а тип сопоставления указан на точное совпадение.
=ПОИСКПОЗ(«в»; ; -1) – результат 3.
=ПОИСКПОЗ(«д»; ; -1) – элемент не найден, хотя присутствует в массиве. Функция возвращает неверный результат, так как последний аргумент принимает значение -1, а элементы НЕ расположены по убыванию.
Для текстовых значений функция допускает использование подстановочных символов «*» и «?».
Если материалы office-menu.ru Вам помогли, то поддержите, пожалуйста, проект, чтобы мы могли развивать его дальше.
У Вас недостаточно прав для комментирования.
Источник
Skip to content
В этом руководстве показано, как использовать ИНДЕКС и ПОИСКПОЗ в Excel и чем они лучше ВПР.
В нескольких недавних статьях мы приложили немало усилий, чтобы объяснить основы функции ВПР новичкам и предоставить более сложные примеры формул ВПР опытным пользователям. А теперь я постараюсь если не отговорить вас от использования ВПР, то хотя бы показать вам альтернативный способ поиска нужных значений в Excel.
- Краткий обзор функций ИНДЕКС и ПОИСКПОЗ
- Как использовать формулу ИНДЕКС ПОИСКПОЗ
- ИНДЕКС+ПОИСКПОЗ вместо ВПР?
- Поиск справа налево
- Двусторонний поиск в строках и столбцах
- ИНДЕКС ПОИСКПОЗ для поиска по нескольким условиям
- Как найти среднее, максимальное и минимальное значение
- Что делать с ошибками поиска?
Для чего это нужно? Потому что функция ВПР имеет множество ограничений, которые могут помешать вам получить желаемый результат во многих ситуациях. С другой стороны, комбинация ПОИСКПОЗ ИНДЕКС более гибкая и имеет много замечательных возможностей, которые во многих отношениях превосходят ВПР.
Функции Excel ИНДЕКС и ПОИСКПОЗ — основы
Поскольку целью этого руководства является демонстрация альтернативного способа выполнения поиска в Excel с использованием комбинации функций ИНДЕКС и ПОИСКПОЗ, мы не будем подробно останавливаться на их синтаксисе и использовании. Тем более, что это подробно рассмотрено в других статьях, ссылки на которые вы можете найти в конце этого руководства. Мы рассмотрим лишь минимум, необходимый для понимания общей идеи, а затем подробно рассмотрим примеры формул, раскрывающие все преимущества использования ПОИСКПОЗ и ИНДЕКС вместо ВПР.
Функция ИНДЕКС
Функция ИНДЕКС (в английском варианте – INDEX) возвращает значение в массиве на основе указанных вами номеров строк и столбцов. Синтаксис функции ИНДЕКС прост:
ИНДЕКС(массив,номер_строки,[номер_столбца])
Вот простое объяснение каждого параметра:
- массив — это диапазон ячеек, именованный диапазон или таблица.
- номер_строки — это номер строки в массиве, из которого нужно вернуть значение. Если этот аргумент опущен, требуется следующий – номер_столбца.
- номер_столбца — это номер столбца, из которого нужно вернуть значение. Если он опущен, требуется номер_строки.
Дополнительные сведения см. в статье Функция ИНДЕКС в Excel .
А вот пример формулы ИНДЕКС в самом простом виде:
=ИНДЕКС(A1:C10;2;3)
Формула выполняет поиск в ячейках с A1 по C10 и возвращает значение ячейки во 2-й строке и 3-м столбце, т. е. в ячейке C2.
Очень легко, правда? Однако при работе с реальными данными вы вряд ли когда-нибудь будете заранее знать, какие строки и столбцы вам нужны. Здесь вам пригодится ПОИСКПОЗ.
Функция ПОИСКПОЗ
Она ищет нужное значение в диапазоне ячеек и возвращает относительное положение этого значения в диапазоне.
Синтаксис функции ПОИСКПОЗ следующий:
ПОИСКПОЗ(искомое_значение, искомый_массив, [тип_совпадения])
- искомое_значение — числовое или текстовое значение, которое вы ищете.
- диапазон_поиска — диапазон ячеек, в которых будем искать.
- тип_совпадения — указывает, следует ли искать точное соответствие или наиболее близкое совпадение:
- 1 или опущено — находит наибольшее значение, которое меньше или равно искомому значению. Требуется сортировка массива поиска в порядке возрастания.
- 0 — находит первое значение, точно равное искомому значению. В комбинации ИНДЕКС/ПОИСКПОЗ вам почти всегда нужно точное совпадение, поэтому вы чаще всего устанавливаете третий аргумент вашей функции в 0.
- -1 — находит наименьшее значение, которое больше или равно искомому значению. Требуется сортировка массива поиска в порядке убывания.
Например, если диапазон B1:B3 содержит значения «яблоки», «апельсины», «лимоны», приведенная ниже формула возвращает число 3, поскольку «лимоны» — это третья по счету запись в этом диапазоне:
=ПОИСКПОЗ(«лимоны»;B1:B3;0)
Дополнительные сведения см . в статье Функция ПОИСКПОЗ в Excel .
На первый взгляд полезность функции ПОИСКПОЗ может показаться сомнительной. Кого волнует положение значения в диапазоне? Что мы действительно хотим определить, так это само значение.
Однако, относительная позиция искомого значения (т. е. номера строки и столбца, в которых оно находится) — это именно то, что нам нужно указать для аргументов номер_строки и номер_столбца функции ИНДЕКС. Как вы помните, ИНДЕКС может найти значение на пересечении заданной строки и столбца, но сама не может определить, какую именно строку и столбец ей нужно выбрать.
Вот поэтому совместное использование ИНДЕКС и ПОИСКПОЗ открывает перед нами массу возможностей для поиска в Excel.
Как использовать формулу ИНДЕКС ПОИСКПОЗ в Excel
Теперь, когда вы знаете основы, я считаю, что вы уже начали понимать, как ПОИСКПОЗ и ИНДЕКС работают вместе. Короче говоря, ИНДЕКС извлекает нужное значение по номерам столбцов и строк, а ПОИСКПОЗ предоставляет ей эти номера. Вот и все!
Для вертикального поиска вы используете функцию ПОИСКПОЗ только для определения номера строки, указывая диапазон столбцов непосредственно в самой формуле:
ИНДЕКС ( столбец для возврата значения ; ПОИСКПОЗ ( искомое значение ; столбец для поиска ; 0))
Все еще не совсем понимаете эту логику? Возможно, будет проще разобрать на примере. Предположим, у вас есть список национальных столиц и их население:
Чтобы найти население определенной столицы, скажем, Индии, используйте следующую формулу ПОИСКПОЗ ИНДЕКС:
=ИНДЕКС(C2:C10; ПОИСКПОЗ(“Индия”;A2:A10;0))
Теперь давайте проанализируем, что на самом деле делает каждый компонент этой формулы:
- Функция ПОИСКПОЗ ищет искомое значение «Индия» в диапазоне A2:A10 и возвращает число 2, поскольку это слово занимает второе место в массиве поиска.
- Этот номер поступает непосредственно в аргумент номер_строки функции ИНДЕКС, предписывая вернуть значение из этой строки.
Таким образом, приведенная выше формула превращается в ИНДЕКС(C2:C10;2), которая означает, что нужно искать в ячейках от C2 до C10 и извлекать значение из второй ячейки в этом диапазоне, то есть из C3, потому что мы начинаем отсчет со второй строки.
Но указывать название города в формуле не совсем правильно, так как для каждого нового поиска придется корректировать эту формулу. Введите его в какую-нибудь отдельную ячейку, скажем, F1, укажите ссылку на ячейку для ПОИСКПОЗ, и вы получите формулу динамического поиска:
=ИНДЕКС(C2:C10;ПОИСКПОЗ(F1;A2:A10;0))
Важное замечание! Количество строк в аргументе массив функции ИНДЕКС должно совпадать с количеством строк в аргументе просматриваемый_массив в ПОИСКПОЗ, иначе формула выдаст неверный результат.
Вы спросите: «А почему бы нам просто не использовать обычную формулу ВПР? Какой смысл тратить время на то, чтобы разобраться в хитросплетениях ИНДЕКС ПОИСКПОЗ в Excel?»
Вот как это будет выглядеть:
=ВПР(F1; A2:C10; 3; 0)
Конечно, так проще. Но этот наш элементарный пример предназначен только для демонстрационных целей, чтобы вы поняли, как именно функции ИНДЕКС и ПОИСКПОЗ работают вместе. Действительно, ВПР была бы здесь более уместна. Другие примеры, которые вы найдёте ниже, покажут вам реальную силу этой комбинации, которая легко справляется со многими сложными задачами, когда ВПР будет бессильна.
ИНДЕКС+ПОИСКПОЗ вместо ВПР?
Решая, какую функцию использовать для вертикального поиска, большинство знатоков Excel сходятся во мнении, что ПОИСКПОЗ+ИНДЕКС намного лучше, чем ВПР. Однако многие до сих пор остаются с ВПР, во-первых, потому что это проще, а, во-вторых, потому что они не до конца понимают все преимущества использования формулы ПОИСКПОЗ ИНДЕКС в Excel. Без такого понимания никто не захочет тратить свое время на изучение более сложного синтаксиса.
Ниже я укажу на ключевые преимущества ИНДЕКС ПОИСКПОЗ перед ВПР, а уж вам решать, является ли это достойным дополнением к вашему арсеналу знаний в Excel.
4 основные причины использовать ИНДЕКС ПОИСКПОЗ вместо ВПР
- Поиск справа налево. Как известно любому образованному пользователю, ВПР не может искать влево. Это означает, что искомое значение всегда должно находиться в крайнем левом столбце таблицы. А извлекать нужное значение мы будем из столбца, который находится правее. ИНДЕКС+ПОИСКПОЗ может легко выполнять поиск влево! Здесь это показано в действии: Как выполнить поиск значения слева в Excel .
- Можно безопасно вставлять или удалять столбцы. Формулы ВПР не работают или выдают неверные результаты, когда новый столбец удаляется из таблицы поиска или добавляется в нее, поскольку синтаксис ВПР требует указания порядкового номера столбца, из которого вы хотите извлечь данные. Естественно, когда вы добавляете или удаляете столбцы, этот номер в формуле автоматически не меняется, а нужный столбец уже оказывается на новом месте.
С функциями ИНДЕКС и ПОИСКПОЗ вы указываете диапазон возвращаемых столбцов, а не номер одного из них. В результате вы можете вставлять и удалять столько столбцов, сколько хотите, не беспокоясь об обновлении каждой связанной с ними формулы.
- Нет ограничений на размер искомого значения. При использовании функции ВПР общая длина ваших критериев поиска не может превышать 255 символов, иначе вы получите ошибку #ЗНАЧ!. Таким образом, если ваш набор данных содержит длинные строки, ИНДЕКС ПОИСКПОЗ — единственное работающее решение.
- Более высокая скорость обработки. Если ваши таблицы относительно небольшие, вряд ли будет какая-то существенная разница в производительности Excel. Но если ваши рабочие листы содержат сотни или тысячи строк и, следовательно, сотни или тысячи формул, ИНДЕКС ПОИСКПОЗ будет работать намного быстрее, чем ВПР. Причина в том, что Excel будет обрабатывать только столбцы поиска и возврата, а не весь массив таблицы.
Влияние ВПР на производительность Excel может быть особенно заметным, если ваша книга содержит сложные формулы массива. Чем больше значений содержит ваш массив и чем больше формул массива содержится в книге, тем медленнее работает Excel.
ИНДЕКС ПОИСКПОЗ в Excel – примеры формул
Уяснив, почему все же стоит изучать ИНДЕКС ПОИСКПОЗ, давайте перейдем к самому интересному и посмотрим, как можно применить теоретические знания на практике.
Формула для поиска справа налево
Как уже упоминалось, ВПР не может получать значения слева от столбца поиска. Таким образом, если ваши значения поиска не находятся в самом левом столбце, нет никаких шансов, что формула ВПР принесет вам желаемый результат. Функция ПОИСКПОЗ ИНДЕКС в Excel более универсальна и не имеет особого значения, где расположены столбцы поиска и возврата.
Для этого примера мы добавим столбец «Ранг» слева от нашей основной таблицы и попытаемся выяснить, какое место занимает столица России по численности населения среди других перечисленных столиц.
Записав искомое значение в G1, используйте следующую формулу для поиска в C2:C10 и возврата соответствующего значения из A2:A10:
=ИНДЕКС(A2:A10; ПОИСКПОЗ(G1;C2:C10;0))
Совет. Если вы планируете использовать формулу ПОИСКПОЗ ИНДЕКС более чем для одной ячейки, обязательно зафиксируйте оба диапазона абсолютными ссылками (например, $A$2:$A$10 и $C$2:$C$10), чтобы они не изменялись при копировании формулы.
Двусторонний поиск в строках и столбцах
В приведенных выше примерах мы использовали ИНДЕКС ПОИСКПОЗ вместо классической функции ВПР, чтобы вернуть значение из точно указанного столбца. Но что, если вам нужно искать в нескольких строках и столбцах? То есть, сначала нужно найти подходящий столбец, а уж потом извлечь из него значение? Другими словами, что, если вы хотите выполнить так называемый матричный или двусторонний поиск?
Это может показаться сложным, но формула очень похожа на базовую функцию ПОИСКПОЗ ИНДЕКС в Excel, но с одним отличием.
Просто используйте две функции ПОИСКПОЗ, вложенных друг в друга: одну – для получения номера строки, а другую – для получения номера столбца.
ИНДЕКС(массив; ПОИСКПОЗ(значение_поиска1 ; столбец_поиска ; 0); ПОИСКПОЗ(значение_поиска2 ; столбец_поиска ; 0))
А теперь, пожалуйста, взгляните на приведенную ниже таблицу и давайте составим формулу двумерного поиска, чтобы найти население (в миллионах) в данной стране за данный год.
С целевой страной в G1 (значение_поиска1) и целевым годом в G2 (значение_поиска2) формула принимает следующий вид:
=ИНДЕКС(B2:D11; ПОИСКПОЗ(G1;A2:A11;0); ПОИСКПОЗ(G2;B1:D1;0))
Как работает эта формула?
Всякий раз, когда вам нужно понять сложную формулу Excel, разделите ее на более мелкие части и посмотрите, что делает каждая отдельная функция:
ПОИСКПОЗ(G1;A2:A11;0); – ищет в A2:A11 значение из ячейки G1 («США») и возвращает его позицию, которая равна 3.
ПОИСКПОЗ(G2;B1:D1;0) – просматривает диапазон B1:D1, чтобы получить позицию значения из ячейки G2 («2015»), которая равна 3.
Найденные выше номера строк и столбцов становятся соответствующими аргументами функции ИНДЕКС:
ИНДЕКС(B2:D11, 3, 3)
В результате вы получите значение на пересечении 3-й строки и 3-го столбца в диапазоне B2:D11, то есть из D4. Несложно?
ИНДЕКС ПОИСКПОЗ для поиска по нескольким условиям
Если у вас была возможность прочитать наши материалы по ВПР в Excel, вы, вероятно, уже протестировали формулу для ВПР с несколькими условиями . Однако существенным недостатком этого подхода является необходимость добавления вспомогательного столбца. Хорошей новостью является то, что функция ПОИСКПОЗ ИНДЕКС в Excel также может выполнять поиск по нескольким условиям без изменения или реструктуризации исходных данных!
Вот общая формула ИНДЕКС ПОИСКПОЗ с несколькими критериями:
{=ИНДЕКС( диапазон_возврата; ПОИСКПОЗ (1; ( критерий1 = диапазон1 ) * ( критерий2 = диапазон2 ); 0))}
Примечание. Это формула массива , которую необходимо вводить с помощью сочетания клавиш Ctrl + Shift + Enter
.
Предположим, что в таблице ниже вы хотите найти значение на основе двух критериев: Покупатель и Товар.
Следующая формула ИНДЕКС ПОИСКПОЗ отлично работает:
=ИНДЕКС(C2:C10; ПОИСКПОЗ(1; (F1=A2:A10) * (F2=B2:B10); 0))
Где C2:C10 — это диапазон, из которого возвращается значение, F1 — это критерий1, A2:A10 — это диапазон для сравнения с критерием 1, F2 — это критерий 2, а B2:B10 — это диапазон для сравнения с критерием 2.
Не забудьте правильно ввести формулу, нажав Ctrl + Shift + Enter, и Excel автоматически заключит ее в фигурные скобки, как показано на скриншоте ниже:
Рис5
Если вы не хотите использовать формулы массива, добавьте в формулу в F4 еще одну функцию ИНДЕКС и завершите ее ввод обычным нажатием Enter:
=ИНДЕКС(C2:C10; ПОИСКПОЗ(1; ИНДЕКС((F1=A2:A10) * (F2=B2:B10); 0; 1); 0))
Разберем пошагово, как это работает.
Здесь используется тот же подход, что и в обычном сочетании ИНДЕКС ПОИСКПОЗ, где просматривается один столбец. Чтобы оценить несколько критериев, вы создаете два или более массива значений ИСТИНА и ЛОЖЬ, которые представляют совпадения и несовпадения для каждого отдельного критерия, а затем перемножаете соответствующие элементы этих массивов. Операция умножения преобразует ИСТИНА и ЛОЖЬ в 1 и 0 соответственно и создает массив, в котором единицы соответствуют строкам, которые удовлетворяют всем условиям. Функция ПОИСКПОЗ со значением поиска 1 находит первую «1» в массиве и передает ее позицию в ИНДЕКС, которая возвращает значение в этой позиции из указанного столбца.
Вторая формула без массива основана на способности функции ИНДЕКС работать с массивами. Второй вложенный ИНДЕКС имеет 0 в номер_строки , так что он будет передавать весь массив столбцов в ПОИСКПОЗ.
Среднее, максимальное и минимальное значение при помощи ИНДЕКС ПОИСКПОЗ
Microsoft Excel имеет специальные функции для поиска минимального, максимального и среднего значения в диапазоне. Но что, если вам нужно получить значение из другой ячейки, связанной с этими значениями? Например, получить название города с максимальным населением или узнать товар с минимальными продажами? В этом случае используйте функцию МАКС , МИН или СРЗНАЧ вместе с ИНДЕКС ПОИСКПОЗ.
Максимальное значение.
Предположим, нам нужно в списке городов найти столицу с самым большим населением. Чтобы найти наибольшее значение в столбце С и вернуть соответствующее ему значение из столбца В, находящееся в той же строке, используйте эту формулу:
=ИНДЕКС(B2:B10; ПОИСКПОЗ(МАКС(C2:C10); C2:C10; 0))
Скриншот с примером находится чуть ниже.
Минимальное значение
Теперь найдём город с самым маленьким населением в списке. Чтобы найти наименьшее число в столбце С и получить соответствующее ему значение из столбца В:
=ИНДЕКС(B2:B10; ПОИСКПОЗ(МИН(C2:C10); C2:C10; 0))
Ближайшее к среднему
Теперь мы находим город, население которого наиболее близко к среднему значению. Чтобы вычислить позицию, наиболее близкую к среднему значению показателя, рассчитанному из D2:D10, и получить соответствующее значение из столбца C, используйте следующую формулу:
=ИНДЕКС(B2:B10; ПОИСКПОЗ(СРЗНАЧ(C2:C10); C2:C10; -1 ))
В зависимости от того, как организованы ваши данные, укажите 1 или -1 для третьего аргумента (тип_совпадения) функции ПОИСКПОЗ:
- Если ваш столбец поиска (столбец D в нашем случае) отсортирован по возрастанию , поставьте 1. Формула вычислит наибольшее значение, которое меньше или равно среднему значению.
- Если ваш столбец поиска отсортирован по убыванию , введите -1. Формула вычислит наименьшее значение, которое больше или равно среднему значению.
- Если ваш массив поиска содержит значение , точно равное среднему, вы можете ввести 0 для точного совпадения. Никакой сортировки не требуется.
В нашем примере данные в столбце D отсортированы в порядке убывания, поэтому мы используем -1 для типа соответствия. В результате мы получаем «Токио», так как его население (13 189 000) является ближайшим, превышающим среднее значение (12 269 006).
Что делать с ошибками поиска?
Как вы, наверное, заметили, если формула ИНДЕКС ПОИСКПОЗ в Excel не может найти искомое значение, она выдает ошибку #Н/Д. Если вы хотите заменить это стандартное сообщение чем-то более информативным, оберните формулу ПОИСКПОЗ ИНДЕКС в функцию ЕСНД . Например:
=ЕСНД(ИНДЕКС(C2:C10; ПОИСКПОЗ(F1;A2:A10;0)); «Не найдено»)
И теперь, если кто-то вводит значение, которое не существует в диапазоне поиска, формула явно сообщит пользователю, что совпадений не найдено:
Если вы хотите перехватывать все ошибки, а не только #Н/Д, используйте функцию ЕСЛИОШИБКА вместо ЕСНД:
=ЕСЛИОШИБКА(ИНДЕКС(C2:C10; ПОИСКПОЗ(F1;A2:A10;0)); «Что-то пошло не так!»)
Пожалуйста, имейте в виду, что во многих ситуациях было бы не совсем правильно скрывать все такие ошибки, потому что они предупреждают вас о возможных проблемах в вашей формуле.
Итак, еще раз об основных преимуществах формулы ИНДЕКС ПОИСКПОЗ.
-
Возможен ли «левый» поиск?
-
Повлияет ли на результат вставка и удаление столбцов?
Вы можете вставлять и удалять столько столбцов, сколько хотите. На результат ИНДЕКС ПОИСКПОЗ это не повлияет.
-
Возможен ли поиск по строкам и столбцам?
Можно сначала найти подходящий столбец, а уж потом извлечь из него значение. Общий вид формулы:
ИНДЕКС(массив; ПОИСКПОЗ(значение_поиска1 ; столбец_поиска ; 0); ПОИСКПОЗ(значение_поиска2 ; столбец_поиска ; 0))
Подробную инструкцию смотрите здесь. -
Как сделать поиск ИНДЕКС ПОИСКПОЗ по нескольким условиям?
Можно выполнять поиск по двум или более условиям без добавления дополнительных столбцов. Вот формула массива, которая решит проблему:
{=ИНДЕКС( диапазон_возврата; ПОИСКПОЗ (1; ( критерий1 = диапазон1 ) * ( критерий2 = диапазон2 ); 0))}
Вот как можно использовать ИНДЕКС и ПОИСКПОЗ в Excel. Я надеюсь, что наши примеры формул окажутся полезными для вас.
Вот еще несколько статей по этой теме:
Список номеров строк, в которых находится искомый параметр |
||||||||
Ответить |
||||||||
Ответить |
||||||||
Ответить |
||||||||
Ответить |
||||||||
Ответить |
||||||||
Ответить |
||||||||
Ответить |
||||||||
Ответить |
||||||||
Ответить |
||||||||
Ответить |
||||||||
Ответить |
Функции ИНДЕКС и ПОИСКПОЗ в 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
второй таблицы поиска
Этот учебник рассказывает о главных преимуществах функций ИНДЕКС и ПОИСКПОЗ в Excel, которые делают их более привлекательными по сравнению с ВПР. Вы увидите несколько примеров формул, которые помогут Вам легко справиться со многими сложными задачами, перед которыми функция ВПР бессильна.
В нескольких недавних статьях мы приложили все усилия, чтобы разъяснить начинающим пользователям основы функции ВПР и показать примеры более сложных формул для продвинутых пользователей. Теперь мы попытаемся, если не отговорить Вас от использования ВПР, то хотя бы показать альтернативные способы реализации вертикального поиска в Excel.
Зачем нам это? – спросите Вы. Да, потому что ВПР – это не единственная функция поиска в Excel, и её многочисленные ограничения могут помешать Вам получить желаемый результат во многих ситуациях. С другой стороны, функции ИНДЕКС и ПОИСКПОЗ – более гибкие и имеют ряд особенностей, которые делают их более привлекательными, по сравнению с ВПР.
- Базовая информация об ИНДЕКС и ПОИСКПОЗ
- Используем функции ИНДЕКС и ПОИСКПОЗ в Excel
- Преимущества ИНДЕКС и ПОИСКПОЗ перед ВПР
- ИНДЕКС и ПОИСКПОЗ – примеры формул
- Как находить значения, которые находятся слева
- Вычисления при помощи ИНДЕКС и ПОИСКПОЗ
- Поиск по известным строке и столбцу
- Поиск по нескольким критериям
- ИНДЕКС и ПОИСКПОЗ в сочетании с ЕСЛИОШИБКА
Содержание
- Базовая информация об ИНДЕКС и ПОИСКПОЗ
- ИНДЕКС – синтаксис и применение функции
- ПОИСКПОЗ – синтаксис и применение функции
- Как использовать ИНДЕКС и ПОИСКПОЗ в Excel
- Почему ИНДЕКС/ПОИСКПОЗ лучше, чем ВПР?
- 4 главных преимущества использования ПОИСКПОЗ/ИНДЕКС в Excel:
- ИНДЕКС и ПОИСКПОЗ – примеры формул
- Как выполнить поиск с левой стороны, используя ПОИСКПОЗ и ИНДЕКС
- Вычисления при помощи ИНДЕКС и ПОИСКПОЗ в Excel (СРЗНАЧ, МАКС, МИН)
- О чём нужно помнить, используя функцию СРЗНАЧ вместе с ИНДЕКС и ПОИСКПОЗ
- Как при помощи ИНДЕКС и ПОИСКПОЗ выполнять поиск по известным строке и столбцу
- Поиск по нескольким критериям с ИНДЕКС и ПОИСКПОЗ
- ИНДЕКС и ПОИСКПОЗ в сочетании с ЕСЛИОШИБКА в Excel
Базовая информация об ИНДЕКС и ПОИСКПОЗ
Так как задача этого учебника – показать возможности функций ИНДЕКС и ПОИСКПОЗ для реализации вертикального поиска в Excel, мы не будем задерживаться на их синтаксисе и применении.
Приведём здесь необходимый минимум для понимания сути, а затем разберём подробно примеры формул, которые показывают преимущества использования ИНДЕКС и ПОИСКПОЗ вместо ВПР.
ИНДЕКС – синтаксис и применение функции
Функция INDEX (ИНДЕКС) в Excel возвращает значение из массива по заданным номерам строки и столбца. Функция имеет вот такой синтаксис:
INDEX(array,row_num,[column_num])
ИНДЕКС(массив;номер_строки;[номер_столбца])
Каждый аргумент имеет очень простое объяснение:
- array (массив) – это диапазон ячеек, из которого необходимо извлечь значение.
- row_num (номер_строки) – это номер строки в массиве, из которой нужно извлечь значение. Если не указан, то обязательно требуется аргумент column_num (номер_столбца).
- column_num (номер_столбца) – это номер столбца в массиве, из которого нужно извлечь значение. Если не указан, то обязательно требуется аргумент row_num (номер_строки)
Если указаны оба аргумента, то функция ИНДЕКС возвращает значение из ячейки, находящейся на пересечении указанных строки и столбца.
Вот простейший пример функции INDEX (ИНДЕКС):
=INDEX(A1:C10,2,3)
=ИНДЕКС(A1:C10;2;3)
Формула выполняет поиск в диапазоне A1:C10 и возвращает значение ячейки во 2-й строке и 3-м столбце, то есть из ячейки C2.
Очень просто, правда? Однако, на практике Вы далеко не всегда знаете, какие строка и столбец Вам нужны, и поэтому требуется помощь функции ПОИСКПОЗ.
ПОИСКПОЗ – синтаксис и применение функции
Функция MATCH (ПОИСКПОЗ) в Excel ищет указанное значение в диапазоне ячеек и возвращает относительную позицию этого значения в диапазоне.
Например, если в диапазоне B1:B3 содержатся значения New-York, Paris, London, тогда следующая формула возвратит цифру 3, поскольку «London» – это третий элемент в списке.
=MATCH("London",B1:B3,0)
=ПОИСКПОЗ("London";B1:B3;0)
Функция MATCH (ПОИСКПОЗ) имеет вот такой синтаксис:
MATCH(lookup_value,lookup_array,[match_type])
ПОИСКПОЗ(искомое_значение;просматриваемый_массив;[тип_сопоставления])
- lookup_value (искомое_значение) – это число или текст, который Вы ищите. Аргумент может быть значением, в том числе логическим, или ссылкой на ячейку.
- lookup_array (просматриваемый_массив) – диапазон ячеек, в котором происходит поиск.
- match_type (тип_сопоставления) – этот аргумент сообщает функции ПОИСКПОЗ, хотите ли Вы найти точное или приблизительное совпадение:
- 1 или не указан – находит максимальное значение, меньшее или равное искомому. Просматриваемый массив должен быть упорядочен по возрастанию, то есть от меньшего к большему.
- 0 – находит первое значение, равное искомому. Для комбинации ИНДЕКС/ПОИСКПОЗ всегда нужно точное совпадение, поэтому третий аргумент функции ПОИСКПОЗ должен быть равен 0.
- -1 – находит наименьшее значение, большее или равное искомому значению. Просматриваемый массив должен быть упорядочен по убыванию, то есть от большего к меньшему.
На первый взгляд, польза от функции ПОИСКПОЗ вызывает сомнение. Кому нужно знать положение элемента в диапазоне? Мы хотим знать значение этого элемента!
Позвольте напомнить, что относительное положение искомого значения (т.е. номер строки и/или столбца) – это как раз то, что мы должны указать для аргументов row_num (номер_строки) и/или column_num (номер_столбца) функции INDEX (ИНДЕКС). Как Вы помните, функция ИНДЕКС может возвратить значение, находящееся на пересечении заданных строки и столбца, но она не может определить, какие именно строка и столбец нас интересуют.
Как использовать ИНДЕКС и ПОИСКПОЗ в Excel
Теперь, когда Вам известна базовая информация об этих двух функциях, полагаю, что уже становится понятно, как функции ПОИСКПОЗ и ИНДЕКС могут работать вместе. ПОИСКПОЗ определяет относительную позицию искомого значения в заданном диапазоне ячеек, а ИНДЕКС использует это число (или числа) и возвращает результат из соответствующей ячейки.
Ещё не совсем понятно? Представьте функции ИНДЕКС и ПОИСКПОЗ в таком виде:
=INDEX(столбец из которого извлекаем,(MATCH (искомое значение,столбец в котором ищем,0))
=ИНДЕКС(столбец из которого извлекаем;(ПОИСКПОЗ(искомое значение;столбец в котором ищем;0))
Думаю, ещё проще будет понять на примере. Предположим, у Вас есть вот такой список столиц государств:
Давайте найдём население одной из столиц, например, Японии, используя следующую формулу:
=INDEX($D$2:$D$10,MATCH("Japan",$B$2:$B$10,0))
=ИНДЕКС($D$2:$D$10;ПОИСКПОЗ("Japan";$B$2:$B$10;0))
Теперь давайте разберем, что делает каждый элемент этой формулы:
- Функция MATCH (ПОИСКПОЗ) ищет значение «Japan» в столбце B, а конкретно – в ячейках B2:B10, и возвращает число 3, поскольку «Japan» в списке на третьем месте.
- Функция INDEX (ИНДЕКС) использует 3 для аргумента row_num (номер_строки), который указывает из какой строки нужно возвратить значение. Т.е. получается простая формула:
=INDEX($D$2:$D$10,3)
=ИНДЕКС($D$2:$D$10;3)
Формула говорит примерно следующее: ищи в ячейках от D2 до D10 и извлеки значение из третьей строки, то есть из ячейки D4, так как счёт начинается со второй строки.
Вот такой результат получится в Excel:
Важно! Количество строк и столбцов в массиве, который использует функция INDEX (ИНДЕКС), должно соответствовать значениям аргументов row_num (номер_строки) и column_num (номер_столбца) функции MATCH (ПОИСКПОЗ). Иначе результат формулы будет ошибочным.
Стоп, стоп… почему мы не можем просто использовать функцию VLOOKUP (ВПР)? Есть ли смысл тратить время, пытаясь разобраться в лабиринтах ПОИСКПОЗ и ИНДЕКС?
=VLOOKUP("Japan",$B$2:$D$2,3)
=ВПР("Japan";$B$2:$D$2;3)
В данном случае – смысла нет! Цель этого примера – исключительно демонстрационная, чтобы Вы могли понять, как функции ПОИСКПОЗ и ИНДЕКС работают в паре. Последующие примеры покажут Вам истинную мощь связки ИНДЕКС и ПОИСКПОЗ, которая легко справляется с многими сложными ситуациями, когда ВПР оказывается в тупике.
Почему ИНДЕКС/ПОИСКПОЗ лучше, чем ВПР?
Решая, какую формулу использовать для вертикального поиска, большинство гуру Excel считают, что ИНДЕКС/ПОИСКПОЗ намного лучше, чем ВПР. Однако, многие пользователи Excel по-прежнему прибегают к использованию ВПР, т.к. эта функция гораздо проще. Так происходит, потому что очень немногие люди до конца понимают все преимущества перехода с ВПР на связку ИНДЕКС и ПОИСКПОЗ, а тратить время на изучение более сложной формулы никто не хочет.
Далее я попробую изложить главные преимущества использования ПОИСКПОЗ и ИНДЕКС в Excel, а Вы решите – остаться с ВПР или переключиться на ИНДЕКС/ПОИСКПОЗ.
4 главных преимущества использования ПОИСКПОЗ/ИНДЕКС в Excel:
1. Поиск справа налево. Как известно любому грамотному пользователю Excel, ВПР не может смотреть влево, а это значит, что искомое значение должно обязательно находиться в крайнем левом столбце исследуемого диапазона. В случае с ПОИСКПОЗ/ИНДЕКС, столбец поиска может быть, как в левой, так и в правой части диапазона поиска. Пример: Как находить значения, которые находятся слева покажет эту возможность в действии.
2. Безопасное добавление или удаление столбцов. Формулы с функцией ВПР перестают работать или возвращают ошибочные значения, если удалить или добавить столбец в таблицу поиска. Для функции ВПР любой вставленный или удалённый столбец изменит результат формулы, поскольку синтаксис ВПР требует указывать весь диапазон и конкретный номер столбца, из которого нужно извлечь данные.
Например, если у Вас есть таблица A1:C10, и требуется извлечь данные из столбца B, то нужно задать значение 2 для аргумента col_index_num (номер_столбца) функции ВПР, вот так:
=VLOOKUP("lookup value",A1:C10,2)
=ВПР("lookup value";A1:C10;2)
Если позднее Вы вставите новый столбец между столбцами A и B, то значение аргумента придется изменить с 2 на 3, иначе формула возвратит результат из только что вставленного столбца.
Используя ПОИСКПОЗ/ИНДЕКС, Вы можете удалять или добавлять столбцы к исследуемому диапазону, не искажая результат, так как определен непосредственно столбец, содержащий нужное значение. Действительно, это большое преимущество, особенно когда работать приходится с большими объёмами данных. Вы можете добавлять и удалять столбцы, не беспокоясь о том, что нужно будет исправлять каждую используемую функцию ВПР.
3. Нет ограничения на размер искомого значения. Используя ВПР, помните об ограничении на длину искомого значения в 255 символов, иначе рискуете получить ошибку #VALUE! (#ЗНАЧ!). Итак, если таблица содержит длинные строки, единственное действующее решение – это использовать ИНДЕКС/ПОИСКПОЗ.
Предположим, Вы используете вот такую формулу с ВПР, которая ищет в ячейках от B5 до D10 значение, указанное в ячейке A2:
=VLOOKUP(A2,B5:D10,3,FALSE)
=ВПР(A2;B5:D10;3;ЛОЖЬ)
Формула не будет работать, если значение в ячейке A2 длиннее 255 символов. Вместо неё Вам нужно использовать аналогичную формулу ИНДЕКС/ПОИСКПОЗ:
=INDEX(D5:D10,MATCH(TRUE,INDEX(B5:B10=A2,0),0))
=ИНДЕКС(D5:D10;ПОИСКПОЗ(ИСТИНА;ИНДЕКС(B5:B10=A2;0);0))
4. Более высокая скорость работы. Если Вы работаете с небольшими таблицами, то разница в быстродействии Excel будет, скорее всего, не заметная, особенно в последних версиях. Если же Вы работаете с большими таблицами, которые содержат тысячи строк и сотни формул поиска, Excel будет работать значительно быстрее, при использовании ПОИСКПОЗ и ИНДЕКС вместо ВПР. В целом, такая замена увеличивает скорость работы Excel на 13%.
Влияние ВПР на производительность Excel особенно заметно, если рабочая книга содержит сотни сложных формул массива, таких как ВПР+СУММ. Дело в том, что проверка каждого значения в массиве требует отдельного вызова функции ВПР. Поэтому, чем больше значений содержит массив и чем больше формул массива содержит Ваша таблица, тем медленнее работает Excel.
С другой стороны, формула с функциями ПОИСКПОЗ и ИНДЕКС просто совершает поиск и возвращает результат, выполняя аналогичную работу заметно быстрее.
ИНДЕКС и ПОИСКПОЗ – примеры формул
Теперь, когда Вы понимаете причины, из-за которых стоит изучать функции ПОИСКПОЗ и ИНДЕКС, давайте перейдём к самому интересному и увидим, как можно применить теоретические знания на практике.
Как выполнить поиск с левой стороны, используя ПОИСКПОЗ и ИНДЕКС
Любой учебник по ВПР твердит, что эта функция не может смотреть влево. Т.е. если просматриваемый столбец не является крайним левым в диапазоне поиска, то нет шансов получить от ВПР желаемый результат.
Функции ПОИСКПОЗ и ИНДЕКС в Excel гораздо более гибкие, и им все-равно, где находится столбец со значением, которое нужно извлечь. Для примера, снова вернёмся к таблице со столицами государств и населением. На этот раз запишем формулу ПОИСКПОЗ/ИНДЕКС, которая покажет, какое место по населению занимает столица России (Москва).
Как видно на рисунке ниже, формула отлично справляется с этой задачей:
=INDEX($A$2:$A$10,MATCH("Russia",$B$2:$B$10,0))
=ИНДЕКС($A$2:$A$10;ПОИСКПОЗ("Russia";$B$2:$B$10;0))
Теперь у Вас не должно возникать проблем с пониманием, как работает эта формула:
- Во-первых, задействуем функцию MATCH (ПОИСКПОЗ), которая находит положение «Russia» в списке:
=MATCH("Russia",$B$2:$B$10,0))
=ПОИСКПОЗ("Russia";$B$2:$B$10;0))
- Далее, задаём диапазон для функции INDEX (ИНДЕКС), из которого нужно извлечь значение. В нашем случае это A2:A10.
- Затем соединяем обе части и получаем формулу:
=INDEX($A$2:$A$10;MATCH("Russia";$B$2:$B$10;0))
=ИНДЕКС($A$2:$A$10;ПОИСКПОЗ("Russia";$B$2:$B$10;0))
Подсказка: Правильным решением будет всегда использовать абсолютные ссылки для ИНДЕКС и ПОИСКПОЗ, чтобы диапазоны поиска не сбились при копировании формулы в другие ячейки.
Вычисления при помощи ИНДЕКС и ПОИСКПОЗ в Excel (СРЗНАЧ, МАКС, МИН)
Вы можете вкладывать другие функции Excel в ИНДЕКС и ПОИСКПОЗ, например, чтобы найти минимальное, максимальное или ближайшее к среднему значение. Вот несколько вариантов формул, применительно к таблице из предыдущего примера:
1. MAX (МАКС). Формула находит максимум в столбце D и возвращает значение из столбца C той же строки:
=INDEX($C$2:$C$10,MATCH(MAX($D$2:I$10),$D$2:D$10,0))
=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(МАКС($D$2:I$10);$D$2:D$10;0))
Результат: Beijing
2. MIN (МИН). Формула находит минимум в столбце D и возвращает значение из столбца C той же строки:
=INDEX($C$2:$C$10,MATCH(MIN($D$2:I$10),$D$2:D$10,0))
=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(МИН($D$2:I$10);$D$2:D$10;0))
Результат: Lima
3. AVERAGE (СРЗНАЧ). Формула вычисляет среднее в диапазоне D2:D10, затем находит ближайшее к нему и возвращает значение из столбца C той же строки:
=INDEX($C$2:$C$10,MATCH(AVERAGE($D$2:D$10),$D$2:D$10,1))
=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(СРЗНАЧ($D$2:D$10);$D$2:D$10;1))
Результат: Moscow
О чём нужно помнить, используя функцию СРЗНАЧ вместе с ИНДЕКС и ПОИСКПОЗ
Используя функцию СРЗНАЧ в комбинации с ИНДЕКС и ПОИСКПОЗ, в качестве третьего аргумента функции ПОИСКПОЗ чаще всего нужно будет указывать 1 или -1 в случае, если Вы не уверены, что просматриваемый диапазон содержит значение, равное среднему. Если же Вы уверены, что такое значение есть, – ставьте 0 для поиска точного совпадения.
- Если указываете 1, значения в столбце поиска должны быть упорядочены по возрастанию, а формула вернёт максимальное значение, меньшее или равное среднему.
- Если указываете -1, значения в столбце поиска должны быть упорядочены по убыванию, а возвращено будет минимальное значение, большее или равное среднему.
В нашем примере значения в столбце D упорядочены по возрастанию, поэтому мы используем тип сопоставления 1. Формула ИНДЕКС/ПОИСКПОЗ возвращает «Moscow», поскольку величина населения города Москва – ближайшее меньшее к среднему значению (12 269 006).
Как при помощи ИНДЕКС и ПОИСКПОЗ выполнять поиск по известным строке и столбцу
Эта формула эквивалентна двумерному поиску ВПР и позволяет найти значение на пересечении определённой строки и столбца.
В этом примере формула ИНДЕКС/ПОИСКПОЗ будет очень похожа на формулы, которые мы уже обсуждали в этом уроке, с одним лишь отличием. Угадайте каким?
Как Вы помните, синтаксис функции INDEX (ИНДЕКС) позволяет использовать три аргумента:
INDEX(array,row_num,[column_num])
ИНДЕКС(массив;номер_строки;[номер_столбца])
И я поздравляю тех из Вас, кто догадался!
Начнём с того, что запишем шаблон формулы. Для этого возьмём уже знакомую нам формулу ИНДЕКС/ПОИСКПОЗ и добавим в неё ещё одну функцию ПОИСКПОЗ, которая будет возвращать номер столбца.
=INDEX(Ваша таблица,(MATCH(значение для вертикального поиска,столбец, в котором искать,0)),(MATCH(значение для горизонтального поиска,строка в которой искать,0))
=ИНДЕКС(Ваша таблица,(MATCH(значение для вертикального поиска,столбец, в котором искать,0)),(MATCH(значение для горизонтального поиска,строка в которой искать,0))
Обратите внимание, что для двумерного поиска нужно указать всю таблицу в аргументе array (массив) функции INDEX (ИНДЕКС).
А теперь давайте испытаем этот шаблон на практике. Ниже Вы видите список самых населённых стран мира. Предположим, наша задача узнать население США в 2015 году.
Хорошо, давайте запишем формулу. Когда мне нужно создать сложную формулу в Excel с вложенными функциями, то я сначала каждую вложенную записываю отдельно.
Итак, начнём с двух функций ПОИСКПОЗ, которые будут возвращать номера строки и столбца для функции ИНДЕКС:
- ПОИСКПОЗ для столбца – мы ищем в столбце B, а точнее в диапазоне B2:B11, значение, которое указано в ячейке H2 (USA). Функция будет выглядеть так:
=MATCH($H$2,$B$1:$B$11,0)
=ПОИСКПОЗ($H$2;$B$1:$B$11;0)
Результатом этой формулы будет 4, поскольку «USA» – это 4-ый элемент списка в столбце B (включая заголовок).
- ПОИСКПОЗ для строки – мы ищем значение ячейки H3 (2015) в строке 1, то есть в ячейках A1:E1:
=MATCH($H$3,$A$1:$E$1,0)
=ПОИСКПОЗ($H$3;$A$1:$E$1;0)
Результатом этой формулы будет 5, поскольку «2015» находится в 5-ом столбце.
Теперь вставляем эти формулы в функцию ИНДЕКС и вуаля:
=INDEX($A$1:$E$11,MATCH($H$2,$B$1:$B$11,0),MATCH($H$3,$A$1:$E$1,0))
=ИНДЕКС($A$1:$E$11;ПОИСКПОЗ($H$2;$B$1:$B$11;0);ПОИСКПОЗ($H$3;$A$1:$E$1;0))
Если заменить функции ПОИСКПОЗ на значения, которые они возвращают, формула станет легкой и понятной:
=INDEX($A$1:$E$11,4,5))
=ИНДЕКС($A$1:$E$11;4;5))
Эта формула возвращает значение на пересечении 4-ой строки и 5-го столбца в диапазоне A1:E11, то есть значение ячейки E4. Просто? Да!
Поиск по нескольким критериям с ИНДЕКС и ПОИСКПОЗ
В учебнике по ВПР мы показывали пример формулы с функцией ВПР для поиска по нескольким критериям. Однако, существенным ограничением такого решения была необходимость добавлять вспомогательный столбец. Хорошая новость: формула ИНДЕКС/ПОИСКПОЗ может искать по значениям в двух столбцах, без необходимости создания вспомогательного столбца!
Предположим, у нас есть список заказов, и мы хотим найти сумму по двум критериям – имя покупателя (Customer) и продукт (Product). Дело усложняется тем, что один покупатель может купить сразу несколько разных продуктов, и имена покупателей в таблице на листе Lookup table расположены в произвольном порядке.
Вот такая формула ИНДЕКС/ПОИСКПОЗ решает задачу:
{=INDEX('Lookup table'!$A$2:$C$13,MATCH(1,(A2='Lookup table'!$A$2:$A$13)*
(B2='Lookup table'!$B$2:$B$13),0),3)}
{=ИНДЕКС('Lookup table'!$A$2:$C$13;ПОИСКПОЗ(1;(A2='Lookup table'!$A$2:$A$13)*
(B2='Lookup table'!$B$2:$B$13);0);3)}
Эта формула сложнее других, которые мы обсуждали ранее, но вооруженные знанием функций ИНДЕКС и ПОИСКПОЗ Вы одолеете ее. Самая сложная часть – это функция ПОИСКПОЗ, думаю, её нужно объяснить первой.
MATCH(1,(A2='Lookup table'!$A$2:$A$13),0)*(B2='Lookup table'!$B$2:$B$13)
ПОИСКПОЗ(1;(A2='Lookup table'!$A$2:$A$13);0)*(B2='Lookup table'!$B$2:$B$13)
В формуле, показанной выше, искомое значение – это 1, а массив поиска – это результат умножения. Хорошо, что же мы должны перемножить и почему? Давайте разберем все по порядку:
- Берем первое значение в столбце A (Customer) на листе Main table и сравниваем его со всеми именами покупателей в таблице на листе Lookup table (A2:A13).
- Если совпадение найдено, уравнение возвращает 1 (ИСТИНА), а если нет – 0 (ЛОЖЬ).
- Далее, мы делаем то же самое для значений столбца B (Product).
- Затем перемножаем полученные результаты (1 и 0). Только если совпадения найдены в обоих столбцах (т.е. оба критерия истинны), Вы получите 1. Если оба критерия ложны, или выполняется только один из них – Вы получите 0.
Теперь понимаете, почему мы задали 1, как искомое значение? Правильно, чтобы функция ПОИСКПОЗ возвращала позицию только, когда оба критерия выполняются.
Обратите внимание: В этом случае необходимо использовать третий не обязательный аргумент функции ИНДЕКС. Он необходим, т.к. в первом аргументе мы задаем всю таблицу и должны указать функции, из какого столбца нужно извлечь значение. В нашем случае это столбец C (Sum), и поэтому мы ввели 3.
И, наконец, т.к. нам нужно проверить каждую ячейку в массиве, эта формула должна быть формулой массива. Вы можете видеть это по фигурным скобкам, в которые она заключена. Поэтому, когда закончите вводить формулу, не забудьте нажать Ctrl+Shift+Enter.
Если всё сделано верно, Вы получите результат как на рисунке ниже:
ИНДЕКС и ПОИСКПОЗ в сочетании с ЕСЛИОШИБКА в Excel
Как Вы, вероятно, уже заметили (и не раз), если вводить некорректное значение, например, которого нет в просматриваемом массиве, формула ИНДЕКС/ПОИСКПОЗ сообщает об ошибке #N/A (#Н/Д) или #VALUE! (#ЗНАЧ!). Если Вы хотите заменить такое сообщение на что-то более понятное, то можете вставить формулу с ИНДЕКС и ПОИСКПОЗ в функцию ЕСЛИОШИБКА.
Синтаксис функции ЕСЛИОШИБКА очень прост:
IFERROR(value,value_if_error)
ЕСЛИОШИБКА(значение;значение_если_ошибка)
Где аргумент value (значение) – это значение, проверяемое на предмет наличия ошибки (в нашем случае – результат формулы ИНДЕКС/ПОИСКПОЗ); а аргумент value_if_error (значение_если_ошибка) – это значение, которое нужно возвратить, если формула выдаст ошибку.
Например, Вы можете вставить формулу из предыдущего примера в функцию ЕСЛИОШИБКА вот таким образом:
=IFERROR(INDEX($A$1:$E$11,MATCH($G$2,$B$1:$B$11,0),MATCH($G$3,$A$1:$E$1,0)),
"Совпадений не найдено. Попробуйте еще раз!")=ЕСЛИОШИБКА(ИНДЕКС($A$1:$E$11;ПОИСКПОЗ($G$2;$B$1:$B$11;0);ПОИСКПОЗ($G$3;$A$1:$E$1;0));
"Совпадений не найдено. Попробуйте еще раз!")
И теперь, если кто-нибудь введет ошибочное значение, формула выдаст вот такой результат:
Если Вы предпочитаете в случае ошибки оставить ячейку пустой, то можете использовать кавычки («»), как значение второго аргумента функции ЕСЛИОШИБКА. Вот так:
IFERROR(INDEX(массив,MATCH(искомое_значение,просматриваемый_массив,0),"")
ЕСЛИОШИБКА(ИНДЕКС(массив;ПОИСКПОЗ(искомое_значение;просматриваемый_массив;0);"")
Надеюсь, что хотя бы одна формула, описанная в этом учебнике, показалась Вам полезной. Если Вы сталкивались с другими задачами поиска, для которых не смогли найти подходящее решение среди информации в этом уроке, смело опишите свою проблему в комментариях, и мы все вместе постараемся решить её.
Оцените качество статьи. Нам важно ваше мнение:
На чтение 7 мин. Просмотров 29.8k.
Содержание
- Получить первое не пустое значение в списке
- Получить первое текстовое значение в списке
- Получить первое текстовое значение с ГПР
- Получить позицию последнего совпадения
- Получить последнее совпадение содержимого ячейки
- Получить 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)
Функция ПОИСКПОЗ возвращает позицию или «индекс» в первом совпадении на основании значения поиска в диапазоне.
ПОИСКПОЗ поддерживает подстановочное согласование со звездочкой «*» (один или несколько символов) или знаком вопроса «?» (один символ), но только тогда, когда третий аргумент, тип_сопоставления, установлен в ЛОЖЬ или ноль.
Поиск и подстановка по нескольким условиям
Постановка задачи
Если вы продвинутый пользователь Microsoft Excel, то должны быть знакомы с функцией поиска и подстановки ВПР или VLOOKUP (если еще нет, то сначала почитайте эту статью, чтобы им стать). Для тех, кто понимает, рекламировать ее не нужно 🙂 — без нее не обходится ни один сложный расчет в Excel. Есть, однако, одна проблема: эта функция умеет искать данные только по совпадению одного параметра. А если у нас их несколько?
Предположим, что у нас есть база данных по ценам товаров за разные месяцы:
Нужно найти и вытащить цену заданного товара (Нектарин) в определенном месяце (Январь), т.е. получить на выходе152, но автоматически, т.е. с помощью формулы. ВПР в чистом виде тут не поможет, но есть несколько других способов решить эту задачу.
Способ 1. Дополнительный столбец с ключом поиска
Это самый очевидный и простой (хотя и не самый удобный) способ. Поскольку штатная функция ВПР (VLOOKUP) умеет искать только по одному столбцу, а не по нескольким, то нам нужно из нескольких сделать один!
Добавим рядом с нашей таблицей еще один столбец, где склеим название товара и месяц в единое целое с помощью оператора сцепки (&), чтобы получить уникальный столбец-ключ для поиска:
Теперь можно использовать знакомую функцию ВПР (VLOOKUP) для поиска склеенной пары НектаринЯнварь из ячеек H3 и J3 в созданном ключевом столбце:
Плюсы : Простой способ, знакомая функция, работает с любыми данными.
Минусы : Надо делать дополнительный столбец и потом, возможно, еще и прятать его от пользователя. При изменении числа строк в таблице — допротягивать формулу сцепки на новые строки (хотя это можно упростить применением умной таблицы).
Способ 2. Функция СУММЕСЛИМН
Если нужно найти именно число (в нашем случае цена как раз число), то вместо ВПР можно использовать функцию СУММЕСЛИМН (SUMIFS) , появившуюся начиная с Excel 2007. По идее, эта функция выбирает и суммирует числовые значения по нескольким (до 127!) условиям. Но если в нашем списке нет повторяющихся товаров внутри одного месяца, то она просто выведет значение цены для заданного товара и месяца:
Плюсы : Не нужен дополнительный столбец, решение легко масштабируется на большее количество условий (до 127), быстро считает.
Минусы : Работает только с числовыми данными на выходе, не применима для поиска текста, не работает в старых версиях Excel (2003 и ранее).
Способ 3. Формула массива
О том, как спользовать связку функций ИНДЕКС (INDEX) и ПОИСКПОЗ (MATCH) в качестве более мощной альтернативы ВПР я уже подробно описывал (с видео). В нашем же случае, можно применить их для поиска по нескольким столбцам в виде формулы массива. Для этого:
- Выделите пустую зеленую ячейку, где должен быть результат.
- Введите в строке формул в нее следующую формулу:
Как это на самом деле работает:
Функция ИНДЕКС выдает из диапазона цен C2:C161 содержимое N-ой ячейки по порядку. При этом порядковый номер нужной ячейки нам находит функция ПОИСКПОЗ. Она ищет связку названия товара и месяца (НектаринЯнварь) по очереди во всех ячейках склеенного из двух столбцов диапазона A2:A161&B2:B161 и выдает порядковый номер ячейки, где нашла точное совпадение. По сути, это первый способ, но ключевой столбец создается виртуально прямо внутри формулы, а не в ячейках листа.
Плюсы : Не нужен отдельный столбец, работает и с числами и с текстом.
Минусы : Ощутимо тормозит на больших таблицах (как и все формулы массива, впрочем), особенно если указывать диапазоны «с запасом» или сразу целые столбцы (т.е. вместо A2:A161 вводить A:A и т.д.) Многим непривычны формулы массива в принципе (тогда вам сюда).
Работа со строками/столбцами по условию
Данная функция является частью надстройки MulTEx
|
Вызов команды:
MulTEx -группа Ячейки/Диапазоны —Работа со строками/Столбцами —Работа со строками/столбцами по условию
Данная команда позволяет удалить, переместить или скопировать строки/столбцы по различным условиям:
Операция — выбор действия над строками/столбцами. Возможно Удаление, Перемещение и Копирование. Перемещение и Копирование возможно на новый лист или в указанный диапазон того же листа.
Удалить/Переместить/Скопировать — в данном разделе можно выбрать над чем производить Удаление/Копирование/Перемещение: над строками или столбцами, а так же выбрать диапазон для выполнения действий.
Строки — действия будут произведены со строками
Столбцы — действия будут произведены со столбцами
На всем листе — действия над строками/столбцами будут произведены на всем листе
В диапазоне — действия над строками/столбцами будут произведены только внутри указанного диапазона. На картинке выше указан диапазон Лист1!$A$1:$E$25. Это значит, что если выбрано Удаление Строк, то строки будут удалены только в этом диапазоне. Даже если строка 27 листа будет удовлетворять условиям, она не будет удалена, т.к. выходит за пределены указанного диапазона.
Переместить — указывается место назначения для копируемых или перемещаемых строк/столбцов.
На новый лист — в данном случае строки/столбцы будут вставлены на новый лист, который будут создан в ходе выполнения команды. Вставка отобранных строк/столбцов начинается с ячейки А1 нового листа.
Начиная с указанной ячейки — в данном случае строки/столбцы будут вставлены на тот же лист, в котором производится Копирование/Перемещение. Вставка отобранных строк/столбцов начинается именно с указанной ячейки. Примечание: Если указать диапазон для вывода результата внутри диапазона с данными для отбора строк/столбцов, то появится сообщение:
После этого лучше проверить заданные параметры и убедиться в том, что перемещение или копирование строк/столбцов не будет произведено в имеющиеся данные. Это сообщение может появиться даже в том случае, если в ячейках для вывода результата нет данных и в качестве исходных данных указано На всем листе. Что вполне логично, т.к. ячейка для вывода в любом случае расположена на этом листе.
Наименование данного раздела меняется в зависимости от выбранного действия и принимает три значения: Переместить, Скопировать и Не доступно. Не доступно появляется при выборе действия Удалить, т.к. в данном случае определение диапазона для вывода результата не требуется.
Переместить строки — указываются критерии для отбора строк/столбцов к удалению/перемещению/копированию.
- Все пустые — будут удалены все пустые строки/столбцы в указанном диапазоне.
- Если значение ячейки: Ниже в примерах применения данных параметров описаны операции по удалению строк, но все это применимо для любой выбранной операции.
- Равно — будут удалены те строки в ячейках которых есть значение, равное указанному. В критериях можно применять символы подстановки(звездочка( * ), вопр.знак( ? ) ). Например на картинке указан критерий: «*С.Петербург*». Это означает, что если в ячейке будет записано «Произведено в г. С.Петербург 12.03.2008», то данная строка будет удалена. Если же указать «С?Петербург», то будут удалены строки, значение в которых равно либо «С.Петербург», либо «С-Петербург», либо «С Петербург» и т.п. Если же указать «С.Петербург», то будут удалены только те строки, значение которых в точности совпадает с «С.Петербург».
- Не равно — будут удалены те строки в ячейках которых нет значения, равного указанному. Все работает так же, как и при выборе Равно, но в обратном направлении. Т.е. если указать «С.Петербург», то будут удалены все строки, значение которых не равно «С.Петербург».
- Учитывать регистр — при отборе значений будет учитываться регистр критерия или нет. Если не установлено, то при указании равно «С.Петербург» будут удалены строки равные и значению «С.Петербург» и значению «с.петербург».
- В поле ниже указывается номер столбца, в котором просматривать эти критерии. Например, если в этом поле указать 2 и На всем листе, то критерии будут просматриваться во втором столбце листа — $B . Если указать 2 и диапазон $B$1:$E$25, то критерии будут просматриваться во втором столбце указанного диапазона, т.е. в третьем столбце листа — $C . Если данное поле оставить пустым, то значения будут просматриваться во всех столбцах диапазона.
Закрыть форму после выполнения операции — по умолчанию включен. Если снять, то после Удаления/Перемещения/Копирования строк/столбцов форма не закроется и можно будет указать следующий критерий.
Выборка значений из таблицы Excel по условию
Если приходиться работать с большими таблицами определенно найдете в них дублирующийся суммы разбросаны вдоль целого столбца. В тоже время у вас может возникнуть необходимость выбрать данные из таблицы с первым наименьшим числовым значением, которое имеет свои дубликаты. Нужна автоматическая выборка данных по условию. В Excel для этой цели можно успешно использовать формулу в массиве.
Как сделать выборку в Excel по условию
Чтобы определить соответствующие значение первому наименьшему числу нужна выборка из таблицы по условию. Допустим мы хотим узнать первый самый дешевый товар на рынке из данного прайса:
Автоматическую выборку реализует нам формула, которая будет обладать следующей структурой:
В месте «диапазон_данных_для_выборки» следует указать область значений A6:A18 для выборки из таблицы (например, текстовых), из которых функция ИНДЕКС выберет одно результирующие значение. Аргумент «диапазон» означает область ячеек с числовыми значениями, из которых следует выбрать первое наименьшее число. В аргументе «заголовок_столбца» для второй функции СТРОКА, следует указать ссылку на ячейку с заголовком столбца, который содержит диапазон числовых значений.
Естественно эту формулу следует выполнять в массиве. Поэтому для подтверждения ее ввода следует нажимать не просто клавишу Enter, а целую комбинацию клавиш CTRL+SHIFT+Enter. Если все сделано правильно в строке формул появятся фигурные скобки.
Обратите внимание ниже на рисунок, где в ячейку B3 была введена данная формула в массиве:
Выборка соответственного значения с первым наименьшим числом:
С такой формулой нам удалось выбрать минимальное значение относительно чисел. Далее разберем принцип действия формулы и пошагово проанализируем весь порядок всех вычислений.
Как работает выборка по условию
Ключевую роль здесь играет функция ИНДЕКС. Ее номинальное задание – это выбирать из исходной таблицы (указывается в первом аргументе – A6:A18) значения соответственные определенным числам. ИНДЕКС работает с учетом критериев определённых во втором (номер строки внутри таблицы) и третьем (номер столбца в таблице) аргументах. Так как наша исходная таблица A6:A18 имеет только 1 столбец, то третий аргумент в функции ИНДЕКС мы не указываем.
Чтобы вычислить номер строки таблицы напротив наименьшего числа в смежном диапазоне B6:B18 и использовать его в качестве значения для второго аргумента, применяется несколько вычислительных функций.
Функция ЕСЛИ позволяет выбрать значение из списка по условию. В ее первом аргументе указано где проверяется каждая ячейка в диапазоне B6:B18 на наличие наименьшего числового значения: ЕСЛИB6:B18=МИНB6:B18. Таким способом в памяти программы создается массив из логических значений ИСТИНА и ЛОЖЬ. В нашем случаи 3 элемента массива будут содержат значение ИСТИНА, так как минимальное значение 8 содержит еще 2 дубликата в столбце B6:B18.
Следующий шаг – это определение в каких именно строках диапазона находится каждое минимальное значение. Это нам необходимо по причине определения именно первого наименьшего значения. Реализовывается данная задача с помощью функции СТРОКА, она заполняет элементы массива в памяти программы номерами строк листа. Но сначала от всех этих номеров вычитается номер на против первой строки таблицы – B5, то есть число 5. Это делается потому, что функция ИНДЕКС работает с номерами внутри таблицы, а не с номерами рабочего листа Excel. В тоже время функция СТРОКА умеет возвращать только номера строк листа. Чтобы не получилось смещение необходимо сопоставить порядок номеров строк листа и таблицы с помощи вычитанием разницы. Например, если таблица находится на 5-ой строке листа значит каждая строка таблицы будет на 5 меньше чем соответственная строка листа.
После того как будут отобраны все минимальные значения и сопоставлены все номера строк таблицы функция МИН выберет наименьший номер строки. Эта же строка будет содержать первое наименьшее число, которое встречается в столбце B6:B18. На основании этого номера строки функции ИНДЕКС выберет соответствующее значение из таблицы A6:A18. В итоге формула возвращает это значение в ячейку B3 в качестве результата вычисления.
Как выбрать значение с наибольшим числом в Excel
Поняв принцип действия формулы, теперь можно легко ее модифицировать и настраивать под другие условия. Например, формулу можно изменить так, чтобы выбрать первое максимальное значение в Excel:
Если необходимо изменить условия формулы так, чтобы можно было в Excel выбрать первое максимальное, но меньше чем 70:
=70;»»;B6:B18));СТРОКА(B6:B18)-СТРОКА(B5);»»)))’ >
Как в Excel выбрать первое минимальное значение кроме нуля:
Как легко заметить, эти формулы отличаются между собой только функциями МИН и МАКС и их аргументами.
Теперь Вас ни что не ограничивает. Один раз разобравшись с принципами действия формул в массиве Вы сможете легко модифицировать их под множество условий и быстро решать много вычислительных задач.
Как выбрать в Экселе все значения по нескольким условиям
Здравствуйте, друзья. Известные нам функции поиска данных, такие, как ВПР и ПОИСКПОЗ, ищут в массиве первое совпадение и возвращают его. Во многих случаях это и требуется, но что делать, когда следует получить все результаты, а не только первый, и искать их по нескольким критериям, а не по одному?
В этой статье мы решим такую задачу. Описываю пример. Есть ведомость школьных оценок 1-3 классов. Мы хотим выбрать класс, оценку, и увидеть учеников класса, которые получили этот балл:
Задача интересная, и достаточно простая. Однако, нам понадобится сделать дополнительный столбец. Действуем в несколько этапов.
Создание вспомогательной колонки
Сейчас необходимо добавить справа от ведомости еще один столбец. Назовём его «технический», т.к. данные в нем будут неинформативными, вспомогательными.
В этой колонке пронумеруем строки так, чтобы напротив каждой строчки, удовлетворяющей условию поиска, стоял её порядковый номер в таблице-выборке.
Смотрите на рисунке, чего мы хотим добиться. Ищем всех учеников класса, которые получили 5. Первый из списка, кто получил такую оценку – Соколов. Напротив него нужно поставить единичку. Второй в списке – Козлов, даём ему второй номер по порядку, третий – Волков, ему ставим третий номер и т.д. Под этими номерами они потом попадут в табличку с выборкой.
Формулу укажу на примере ячейки D3:
Функция СУММ для каждой строки сложит значение из предыдущей ячейки, а так же, результат сравнения класса в ведомости с искомым, оценки в ведомости с искомыми. Два уточнения:
- В ячейке D2 – текст, и функция СУММ его проигнорирует. В остальных строчках будет браться число из ячейки сверху;
- ФОРМУЛА И(A3=$L$2;C3=$L$3) вернёт ИСТИНУ (единицу), когда оба условия внутри неё выполнятся, или ЛОЖЬ (ноль), если хотя бы одно из условий не выполнится. Таким образом, когда функция И найдет совпадение класса и оценки, СУММ увеличит порядковый номер на единицу, что нам и требовалось
Смотрите на картинке результат. Все найденные совпадения я выделил красным цветом с помощью условного форматирования.
Вывод отобранных строк в таблицу
Теперь осталось вывести на экран выборку учеников класса с нужной оценкой. Для этого сопоставим номера в столбце F с номерами в технической колонке D. Удобнее всего это сделать с помощью комбинации функций ИНДЕКС и ПОИСКПОЗ:
Алгоритм работы на примере ячейки G3:
- Функция ПОИСКПОЗ получает числовой индекс строки из ячейки F3 и ищет такое же значение в техническом столбце D. Возвращает либо порядковый номер найденной ячейки в массиве, либо ошибку #Н/Д
- Функция ИНДЕКС получает из ведомости класс, находящийся в ячейке, порядковый номер которой мы получили в первом пункте
- Далее функция ЕСЛИОШИБКА выводит на экран класс, если он найден, или пустую строку, если ПОИСКПОЗ вернула ошибку
Такой порядок работает и для остальных столбцов: «Фамилия», «Баллы». Теперь если изменить искомый класс или оценку, формулы сами всё пересчитают и переформируют список. Можно скрыть дополнительный столбец, чтобы не мешал.
Для удобного выбора оценки и класса, я создал раскрывающийся список. В этой статье вы можете прочитать, как это делается.
Мы получили полностью автоматизированный интерактивный проект, способный формировать списки «налету», сразу после того, как вы сделаете свой выбор. На этом всё, и я готов отвечать на ваши вопросы!