Поиск и подстановка по нескольким условиям
Постановка задачи
Если вы продвинутый пользователь Microsoft Excel, то должны быть знакомы с функцией поиска и подстановки ВПР или VLOOKUP (если еще нет, то сначала почитайте эту статью, чтобы им стать). Для тех, кто понимает, рекламировать ее не нужно :) - без нее не обходится ни один сложный расчет в Excel. Есть, однако, одна проблема: эта функция умеет искать данные только по совпадению одного параметра. А если у нас их несколько?
Предположим, что у нас есть база данных по ценам товаров за разные месяцы:
Нужно найти и вытащить цену заданного товара (Нектарин) в определенном месяце (Январь), т.е. получить на выходе152, но автоматически, т.е. с помощью формулы. ВПР в чистом виде тут не поможет, но есть несколько других способов решить эту задачу.
Способ 1. Дополнительный столбец с ключом поиска
Это самый очевидный и простой (хотя и не самый удобный) способ. Поскольку штатная функция ВПР (VLOOKUP) умеет искать только по одному столбцу, а не по нескольким, то нам нужно из нескольких сделать один!
Добавим рядом с нашей таблицей еще один столбец, где склеим название товара и месяц в единое целое с помощью оператора сцепки (&), чтобы получить уникальный столбец-ключ для поиска:
Теперь можно использовать знакомую функцию ВПР (VLOOKUP) для поиска склеенной пары НектаринЯнварь из ячеек H3 и J3 в созданном ключевом столбце:
Плюсы: Простой способ, знакомая функция, работает с любыми данными.
Минусы: Надо делать дополнительный столбец и потом, возможно, еще и прятать его от пользователя. При изменении числа строк в таблице - допротягивать формулу сцепки на новые строки (хотя это можно упростить применением умной таблицы).
Способ 2. Функция СУММЕСЛИМН
Если нужно найти именно число (в нашем случае цена как раз число), то вместо ВПР можно использовать функцию СУММЕСЛИМН (SUMIFS), появившуюся начиная с Excel 2007. По идее, эта функция выбирает и суммирует числовые значения по нескольким (до 127!) условиям. Но если в нашем списке нет повторяющихся товаров внутри одного месяца, то она просто выведет значение цены для заданного товара и месяца:
Плюсы: Не нужен дополнительный столбец, решение легко масштабируется на большее количество условий (до 127), быстро считает.
Минусы: Работает только с числовыми данными на выходе, не применима для поиска текста, не работает в старых версиях Excel (2003 и ранее).
Способ 3. Формула массива
О том, как спользовать связку функций ИНДЕКС (INDEX) и ПОИСКПОЗ (MATCH) в качестве более мощной альтернативы ВПР я уже подробно описывал (с видео). В нашем же случае, можно применить их для поиска по нескольким столбцам в виде формулы массива. Для этого:
- Выделите пустую зеленую ячейку, где должен быть результат.
- Введите в строке формул в нее следующую формулу:
- Нажмите в конце не Enter, а сочетание Ctrl+Shift+Enter, чтобы ввести формулу не как обычную, а как формулу массива.
Как это на самом деле работает:
Функция ИНДЕКС выдает из диапазона цен C2:C161 содержимое N-ой ячейки по порядку. При этом порядковый номер нужной ячейки нам находит функция ПОИСКПОЗ. Она ищет связку названия товара и месяца (НектаринЯнварь) по очереди во всех ячейках склеенного из двух столбцов диапазона A2:A161&B2:B161 и выдает порядковый номер ячейки, где нашла точное совпадение. По сути, это первый способ, но ключевой столбец создается виртуально прямо внутри формулы, а не в ячейках листа.
Плюсы: Не нужен отдельный столбец, работает и с числами и с текстом.
Минусы: Ощутимо тормозит на больших таблицах (как и все формулы массива, впрочем), особенно если указывать диапазоны "с запасом" или сразу целые столбцы (т.е. вместо A2:A161 вводить A:A и т.д.) Многим непривычны формулы массива в принципе (тогда вам сюда).
Ссылки по теме
- Как искать и подставлять данные с помощью функции ВПР (VLOOKUP)
- Что такое формулы массива и как их использовать
- Как использовать связку функций ИНДЕКС и ПОИСКПОЗ вместо ВПР
- Как извлечь сразу все значения, а не только первое с помощью ВПР
Либо формула массива:
Где вместо МИН можно использовать МАКС или СУММ (если сочетания Товар/Месяц уникальны)
Данную формулу мне подсказал человек с форума под ником Евгений
=ИНДЕКС($A$1:$D$173;МАКС(ЕСЛИ($A$1:$D$173=G3&I3;СТРОКА($A$1:$D$173)));МАКС(ЕСЛИ($A$1:$D$173=K2;СТОЛБЕЦ($A$1:$D$173))))
Пример по ссылке ниже:
Я привел эти примеры, как дополнительные варианты "выборки".
Ну и еще вариант через ПРОСМОТР:
Из преимуществ - не требует массивного ввода, работает в любой версии Excel, не нужно делать конкатенацию как в примере с ВПР, работает существенно быстрее, чем конструкция с ИНДЕКС(ПОИСКПОЗ) при использовании нулевого интервального просмотра (точного поиска). Особенность - при нескольких сочетаниях товар/месяц, попадающих под выборку - возвратит значение последнего совпадения.
Аналог данной формулы через ИНДЕКС(ПОИСКПОЗ):
Требует массивного ввода и вернет последнее совпадение.
Для первого совпадения:
Но на большом количестве данных эта формула будет работать существенно медленнее , чем предыдущие два варианта.
Откуда появляется переменная "L3" в формуле, если ее надо вычислить??
=СРЗНАЧЕСЛИМН(C:C;A:A;G3;B:B;I3)
соответственно при дубляже строк он выдаст их среднюю.
Николай
такой вопрос, как вы выбираете функцию без мышки и её завершение?
в ролике в набрали "=ин" и что то нажали (время 8:55), и сразу появилось "=Индекс("
А для второго варианта можно исключить повторы используя формулу:
=ЕСЛИОШИБКА(СУММЕСЛИМН(C:C;A:A;G3;B:B;I3)/СЧЁТЕСЛИМН(A:A;G3;B:B;I3);"Ничего не найдено!";)
СРЗНАЧЕСЛИМН(C:C;A:A;G3;B:B;I3) и все.
=ИНДЕКС(C:C;ПОИСКПОЗ(G3&I3;ИНДЕКС(A:A&B:B;0);0))
=INDEX(C:C;MATCH(G3&I3;INDEX(A:A&B:B;0);0))
Если в функции индекс в качестве второго параметра ввести 0, то он отрабатывает как массив
Пробую вашу формулу, и в этом случае в ячейке выпадает "#Н/Д"....
Заранее спасибо..
=ЕСЛИОШИБКА(ИНДЕКС(C:C;ПОИСКПОЗ(G3&I3;ИНДЕКС(A:A&B:B;0);0));0)
=IFERROR(INDEX(C:C;MATCH(G3&I3;INDEX(A:A&B:B;0);0));0)
Спасибо огромное!
Формула массива почему-то не сработала. В формуле были ссылки на столбцы, но название умной таблицы не отражалась.
Формула без использование массива сработала.
Например есть в 1м столбце даты (всегда разные) а во втором суммы. Нужно посчитать какая сумма выходит на 25 число каждого месяца.
Пример:
Дата Оплатили Выставили счёт
30.12.13 15000 руб.
02.01.14 12000 руб.
15.01.14 16000 руб
31.01.14 45000 руб
05.02.14 50000 руб
08.02.14 65000 руб
12.02.14 1000 руб
25.02.14 12000 руб
28.02.14 20000 руб
03.03.14 12000 руб
21.03.14 17000 руб
24.05.14 40000 руб
24.05.14 20000 руб
Нужно знать долг на 25 число каждого месяца.
Помогите пожалуйста.
Пыталась применить способ №3, для меня он наиболее подходит, но формулу применить не смогла, выдает ошибку (#ЗНАЧ!)...
Создала аналог вашего примера, но формула продолжает выдавать ошибку...
Не понимаю в чем проблема:|
У меня все работает.
Большое спасибо за формулу)
Жить стало легче, жить стало веселее! =)
Ну так, для примера, формула для поиска отфильтрованного значения с определенным порядковым номером ))
1
Никак не могу победить подсчет формулы с ИНДЕКС и ПОИСПОЗ... по первому параметру.
Задача такая..
Есть ряд параметров - по ним в массиве данных нужно найти соответствие по 2-м или нескольким совпадениям.
Причем первый параметр повторяющийся расположен в колонке, второй меняется и расположен в строке.
ПОИСКПОЗ - находит первое совпадение по первому параметру, а второе совпадение игнорирует...
Я конечно понимаю что для этой цели нужен 1С, но товарищ (который попросил меня написать данную таблицу) не может забивать свои товары в общую базу.
Помогите пожалуйста. Данные по ценам нужно брать из столбцов I, J, K (страница "Цены";) и подставлять в столбцы J, K, L (страница "Реализация).
Пример по ссылке:
ВПР будет отбирать самое первое значение, т.е. верхнее.
Т.о. если у вас будет фильтр по дате, то и находить функция будет самую "свежую" цену.
Далее принцип поиска цены тот же, что и в статье...
Подскажите, пожалуйста, как можно показать в одной строке в каких месяцах продавался, например, картофель?
Какую формулу следует использовать? Возможно ли это вообще осуществить стандартными формулами без допмакросов?
В моем случае требуется по одному артикулу обуви отобразить В ОДНОЙ СТРОЧКЕ все размеры, какие есть в наличии (столбец артикул обуви, столбец размер обуви).
Есть список привязки номер телефона - должность, также есть таблица привязка должность -тариф , так мне нужно увязать телефон-должность-тариф. индекс _поискпоз делаю не верное знач. Помогите, пжл,.. спасибо
В1=С1
В2=С2
если В3< В1 то В3=0
если В3<B2 и В3≥В1 то В3=С1
если В3 ≥В2 то В3=С2
Не смог на форуме найти тему...
Помогите решить задачу:
на приложенной картинке пример...
нужно провести выборку из умной таблицы по нескольким критериям...
1- номер гаража
2-максимальная дата(или крайняя(последняя календарная дата)
Вывод: состояние баланса на эту дату...
Или поделитесь ссылкой на форум...
Спасибо за Вашу работу!
[img][/img]