Функции ИНДЕКС и ПОИСКПОЗ в 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
второй таблицы поиска
Skip to content
В статье предлагается несколько различных формул для выполнения поиска в двумерном массиве значений Excel. Просмотрите эти варианты и выберите наиболее для вас подходящий.
При поиске данных в электронных таблицах Excel чаще всего вы будете искать вертикально в столбцах или горизонтально в строках. Но иногда вам нужно просматривать сразу два условия – как строки, так и столбцы. Другими словами, вы стремитесь найти значение на пересечении определенной строки и столбца. Это называется матричным поиском (также известным как двумерный или поиск в диапазоне). Далее показано, как это можно сделать различными способами.
- Поиск в массиве при помощи ИНДЕКС ПОИСКПОЗ
- Формула ВПР и ПОИСКПОЗ для поиска в диапазоне
- Функция ПРОСМОТРX для поиска в строках и столбцах
- Формула СУММПРОИЗВ для поиска по строке и столбцу
- Поиск в матрице с именованными диапазонами
Поиск в массиве при помощи ИНДЕКС ПОИСКПОЗ
Самый популярный способ выполнить двусторонний поиск в Excel — использовать комбинацию ИНДЕКС с двумя ПОИСКПОЗ. Это разновидность классической формулы ПОИСКПОЗ ИНДЕКС , к которой вы добавляете еще одну функцию ПОИСКПОЗ, чтобы получить номера строк и столбцов:
ИНДЕКС( массив_данных ; ПОИСКПОЗ( значение_вертикальное ; диапазон_поиска_столбец ; 0), ПОИСКПОЗ( значение_горизонтальное ; диапазон_поиска_строка ; 0))
В этом способе, как и во всех остальных, мы используем поиск по двум условиям. Первое из них должно обнаружить совпадение в определенном столбце (в заголовках строк), а второе – в определенной строке (то есть, в заголовках столбцов). В результате мы имеем строку и столбец, которые соответствуют заданным условиям. А на пересечении их как раз и будут находиться искомые данные.
В качестве примера составим формулу для получения количества проданного товара за определённый период времени из таблицы, которую вы можете видеть ниже. Для начала определим все аргументы:
- Массив_данных — B2:E11 (ячейки данных, не включая заголовки строк и столбцов)
- Значение_вертикальное — H1 (целевой товар)
- Диапазон_поиска_столбец – A2:A11 (заголовки строк: названия напитков)
- Значение_горизонтальное — H2 (целевой период)
- Диапазон_поиска_строка — B1:E1 (заголовки столбцов: временные периоды)
Соедините все аргументы вместе, и вы получите следующую формулу для поиска числа в диапазоне:
=ИНДЕКС(B2:E11; ПОИСКПОЗ(H1;A2:A11;0); ПОИСКПОЗ(H2;B1:E1;0))
Как работает эта формула?
Хотя на первый взгляд это может показаться немного сложным, логика здесь простая. Функция ИНДЕКС извлекает значение из массива данных на основе номеров строк и столбцов, а две функции ПОИСКПОЗ предоставляют ей эти номера:
ИНДЕКС( B2:E11; номер_строки ; номер_столбца )
Здесь мы используем способность ПОИСКПОЗ возвращать относительную позицию значения в искомом массиве .
Итак, чтобы получить номер строки, мы ищем нужный нам товар (H1) в заголовках строк (A2:A11):
ПОИСКПОЗ(H1;A2:A11;0)
Чтобы получить номер столбца, мы ищем нужную нам неделю (H2) в заголовках столбцов (B1:E1):
ПОИСКПОЗ(H2;B1:E1;0)
В обоих случаях мы ищем точное совпадение, присваивая третьему аргументу значение 0.
В этом примере первое ПОИСКПОЗ возвращает 2, потому что нужный товар (Sprite) находится в ячейке A3, которая является второй по счёту в диапазоне A2:A11. Второй ПОИСКПОЗ возвращает 3, так как «Неделя 3» находится в ячейке D1, которая является третьей ячейкой в B1:E1.
С учетом вышеизложенного формула сводится к:
ИНДЕКС(B2:E11; 2 ; 3 )
Она возвращает число на пересечении второй строки и третьего столбца в матрице B2:E4, то есть в ячейке D3.
Думаю, вы понимаете, что аналогичным образом можно производить поиск в двумерном массиве Excel не только числа, но и текста. Тип данных здесь не имеет значения.
Формула ВПР и ПОИСКПОЗ для поиска в диапазоне
Другой способ выполнить матричный поиск в Excel — использовать комбинацию функций ВПР и ПОИСКПОЗ:
ВПР( значение_вертикальное ; массив_данных ; ПОИСКПОЗ( значение_горизонтальное , диапазон_поиска_строка , 0), ЛОЖЬ)
Для нашего образца таблицы формула принимает следующий вид:
=ВПР(H1; A2:E11; ПОИСКПОЗ(H2;A1:E1;0); ЛОЖЬ)
Где:
- Массив_данных — B2:E11 (ячейки данных, не включая заголовки строк и столбцов)
- Значение_вертикальное — H1 (целевой товар)
- Значение_горизонтальное — H2 (целевой период)
- Диапазон_поиска_строка — А1:E1 (заголовки столбцов: временные периоды)
Основой формулы является функция ВПР, настроенная на точное совпадение (последний аргумент имеет значение ЛОЖЬ). Она ищет заданное значение (H1) в первом столбце массива (A2:E11) и возвращает данные из другого столбца в той же строке. Чтобы определить, из какого столбца вернуть значение, вы используете функцию ПОИСКПОЗ, которая также настроена на точное совпадение (последний аргумент равен 0):
ПОИСКПОЗ(H2;A1:E1;0)
ПОИСКПОЗ ищет текст из H2 в заголовках столбцов (A1:E1) и указывает относительное положение найденной ячейки. В нашем случае нужная неделя (3-я) находится в D1, которая является четвертой по счету в массиве поиска. Итак, число 4 идет в аргумент номер_столбца функции ВПР:
=ВПР(H1; A2:E11; 4; ЛОЖЬ)
Далее ВПР находит точное совпадение H1 со значением в A3 и возвращает значение из 4-го столбца в той же строке, то есть из ячейки D3.
Важное замечание! Чтобы формула работала корректно, диапазон_поиска (A2:E11) функции ВПР и диапазон_поиска (A1:E1) функции ПОИСКПОЗ должны иметь одинаковое количество столбцов. Иначе число, переданное в номер_столбца, будет неправильным (не будет соответствовать положению столбца в массиве данных).
Функция ПРОСМОТРX для поиска в строках и столбцах
Недавно Microsoft представила еще одну функцию в Excel, которая призвана заменить все существующие функции поиска, такие как ВПР, ГПР и ИНДЕКС+ПОИСКПОЗ. Помимо прочего, ПРОСМОТРX может смотреть на пересечение определенной строки и столбца:
ПРОСМОТРX( значение_вертикальное ; диапазон_поиска_столбец ; ПРОСМОТРX( значение_горизонтальное ; диапазон_поиска_строка ; массив_данных ))
Для нашего примера набора данных формула выглядит следующим образом:
=ПРОСМОТРX(H1; A2:A11; ПРОСМОТРX(H2; B1:E1; B2:E11))
Примечание. В настоящее время ПРОСМОТРX — это функция, доступная только подписчикам Office 365 и более поздних версий.
В формуле используется функция ПРОСМОТРX для возврата всей строки или столбца. Внутренняя функция ищет целевой период времени в строке заголовка и возвращает все значения для этой недели (в данном примере для 3-й). Эти значения переходят в аргумент возвращаемый_массив внешнего ПРОСМОТРX:
=ПРОСМОТРX(H1; A2:A11; {544:87:488:102:87:433:126:132:111:565})
Внешняя функция ПРОСМОТРX ищет нужный товар в заголовках столбцов и извлекает значение из той же позиции из возвращаемого_массива.
Формула СУММПРОИЗВ для поиска по строке и столбцу
Функция СУММПРОИЗВ чрезвычайно универсальна — она может делать множество вещей, выходящих за рамки ее предназначения, особенно когда речь идет об оценке нескольких условий.
Чтобы найти значение на пересечении определенных строки и столбца, используйте эту общую формулу:
СУММПРОИЗВ ( диапазон_поиска_столбец = значение_вертикальное ) * ( диапазон_поиска_строка = значение_горизонтальное), массив_данных )
Чтобы выполнить поиск данных в массиве по строке и столбцу в нашем наборе данных, формула выглядит следующим образом:
=СУММПРОИЗВ((A2:A11=H1)*(B1:E1=H2); B2:E11)
Приведенный ниже вариант также будет работать:
=СУММПРОИЗВ((A2:A11=H1)*(B1:E1=H2)*B2:E11)
Теперь поясним подробнее. В начале мы сравниваем два значения поиска с заголовками строк и столбцов (целевой товар в H1 со всеми наименованиями в A2: A11 и целевой период времени в H2 со всеми неделями в B1: E1):
(A2:A11=H1)*(B1:E1=H2)
Это дает нам два массива значений ИСТИНА и ЛОЖЬ, где ИСТИНА означает совпадения:
{ЛОЖЬ:ИСТИНА:ЛОЖЬ:ЛОЖЬ:ЛОЖЬ:ЛОЖЬ:ЛОЖЬ:ЛОЖЬ:ЛОЖЬ:ЛОЖЬ}) * ({ЛОЖЬ;ЛОЖЬ;ИСТИНА;ЛОЖЬ}
Операция умножения преобразует значения ИСТИНА и ЛОЖЬ в 1 и 0 и создает матрицу из 4 столбцов и 10 строк (строки разделяются двоеточием, а каждый столбец данных — точкой с запятой):
{0;0;0;0:0;0;1;0:0;0;0;0:0;0;0;0:0;0;0;0:0;0;0;0:0;0;0;0:0;0;0;0:0;0;0;0:0;0;0;0}
Функция СУММПРОИЗВ умножает элементы приведенного выше массива на элементы B2:E4, находящихся в тех же позициях:
{0;0;0;0:0;0;1;0:0;0;0;0:0;0;0;0:0;0;0;0:0;0;0;0:0;0; 0;0:0;0;0;0:0;0;0;0:0;0;0;0} * {455;345;544;366:65;77;87;56:766; 655;488;865:129;66;102;56:89;141;87;89:566;511;433;522:154; 144;126; 162:158;165;132;155:112;143;111; 125:677;466;565;766})
И поскольку умножение на ноль дает в результате ноль, остается только элемент, соответствующий 1 в первом массиве:
=СУММПРОИЗВ({0;0;0;0:0;0;87;0:0;0;0;0:0;0;0;0:0;0;0;0:0; 0;0;0:0;0;0;0:0;0;0;0:0;0;0;0:0;0;0;0})
Наконец, СУММПРОИЗВ складывает все элементы результирующего массива и возвращает значение 87.
Примечание . Если в вашей таблице несколько заголовков строк и/или столбцов с одинаковыми именами, итоговый массив будет содержать более одного числа, отличного от нуля. И все эти числа будут суммированы. В результате вы получите сумму значений, удовлетворяющую обоим критериям. Это то, что отличает формулу СУММПРОИЗВ от ПОИСКПОЗ и ВПР, которые возвращают только первое найденное совпадение.
Поиск в матрице с именованными диапазонами
Еще один достаточно простой способ поиска в массиве в Excel — использование именованных диапазонов. Рассмотрим пошагово:
Шаг 1. Назовите столбцы и строки
Самый быстрый способ назвать каждую строку и каждый столбец в вашей таблице:
- Выделите всю таблицу (в нашем случае A1:E11).
- На вкладке « Формулы » в группе « Определенные имена » щелкните « Создать из выделенного » или нажмите комбинацию клавиш Ctrl + Shift + F3.
- В диалоговом окне « Создание имени из выделенного » выберите « в строке выше » и « в столбце слева» и нажмите «ОК».
Это автоматически создает имена на основе заголовков строк и столбцов. Однако есть пара предостережений:
- Если ваши заголовки столбцов и/или строк являются числами или содержат определенные символы, которые не разрешены в именах Excel, то имена для таких столбцов и строк не будут созданы. Чтобы просмотреть список созданных имен, откройте Диспетчер имен (
Ctrl + F3
). Если некоторые имена отсутствуют, определите их вручную. - Если некоторые из ваших заголовков строк или столбцов содержат пробелы, то они будут заменены символами подчеркивания, например, Неделя_1.
Шаг 2. Создание формулы поиска по матрице
Чтобы получить значение из матрицы на пересечении определенной строки и столбца, просто введите одну из следующих общих формул в пустую ячейку:
=имя_строки имя_столбца
Или наоборот:
=имя_столбца имя_строки
Например, чтобы получить продажу Sprite в 3-й неделе, используйте выражение:
=Sprite неделя_3
То есть, имена диапазонов здесь разделены пробелом, который в данном случае является оператором пересечения массивов.
Если кому-то нужны более подробные инструкции, опишем весь процесс пошагово:
- В ячейке, в которой вы хотите отобразить результат, введите знак равенства (=).
- Начните вводить имя целевой строки, Sprite. После того, как вы введете пару символов, Excel отобразит все существующие имена, соответствующие вашему вводу. Дважды щелкните нужное имя, чтобы ввести его в формулу.
- После имени строки введите пробел , который в данном случае работает как оператор пересечения.
- Введите имя целевого столбца ( в нашем случае неделя_3 ).
- Как только будут введены имена строки и столбца, Excel выделит соответствующую строку и столбец в вашей таблице, и вы нажмете Enter, чтобы завершить ввод:
Ваш поиск нужной ячейки в массиве выполнен, найден результат 87.
Вот какими способами можно выполнять поиск в массиве значений – в строках и столбцах таблицы Excel. Я благодарю вас за чтение и надеюсь еще увидеть вас в нашем блоге.
Еще несколько материалов по теме:
Поиск и подстановка по нескольким условиям
Постановка задачи
Если вы продвинутый пользователь 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)
- Что такое формулы массива и как их использовать
- Как использовать связку функций ИНДЕКС и ПОИСКПОЗ вместо ВПР
- Как извлечь сразу все значения, а не только первое с помощью ВПР
Поиск значений в списке данных
Примечание: Мы стараемся как можно оперативнее обеспечивать вас актуальными справочными материалами на вашем языке. Эта страница переведена автоматически, поэтому ее текст может содержать неточности и грамматические ошибки. Для нас важно, чтобы эта статья была вам полезна. Просим вас уделить пару секунд и сообщить, помогла ли она вам, с помощью кнопок внизу страницы. Для удобства также приводим ссылку на оригинал (на английском языке).
Предположим, вам нужно найти расширение телефона сотрудника с помощью его номера, а также правильно оценить коэффициент Комиссии для суммы продажи. Вы ищете данные, чтобы быстро и эффективно находить определенные данные в списке и автоматически проверять, правильно ли используются данные. После того как вы просмотрит данные, вы можете выполнить вычисления и отобразить результаты, указав возвращаемые значения. Есть несколько способов поиска значений в списке данных и отображения результатов.
В этой статье
Поиск значений в списке по вертикали по точному совпадению
Для выполнения этой задачи можно использовать функцию ВПР или сочетание функций индекс и ПОИСКПОЗ.
Примеры использования функции ВПР
Дополнительные сведения можно найти в разделе функция ВПР.
Примеры ИНДЕКСов и СОВПАДЕНИй
=ИНДЕКС(нужно вернуть значение из C2:C10, которое будет соответствовать ПОИСКПОЗ(первое значение «Капуста» в массиве B2:B10))
Формула ищет первое значение в ячейке C2: C10, соответствующее капусты (в B7), и возвращает значение в C7 (100) — первое значение, соответствующее капусты.
Дополнительные сведения можно найти в разделе Функция индекс и функция ПОИСКПОЗ.
Поиск значений в списке по вертикали по приблизительному совпадению
Для этого используйте функцию ВПР.
Важно: Убедитесь, что значения в первой строке отсортированы в возрастающем порядке.
В приведенном выше примере функция ВПР ищет имя учащегося, у которого есть 6 тардиес в диапазоне A2: B7. В таблице нет записи для 6 тардиес, поэтому функция ВПР ищет следующее самое высокое соответствие ниже 6 и находит значение 5, связанное с первым именем Дэйв, и, следовательно, возвращает Дэйв.
Дополнительные сведения можно найти в разделе функция ВПР.
Поиск значений по вертикали в списке неизвестного размера с точным соответствием
Для выполнения этой задачи используйте функции СМЕЩ и ПОИСКПОЗ.
Примечание: Этот подход используется, если данные находятся в диапазоне внешних данных, который вы обновляете каждый день. Вы знаете, что в столбце B есть Цена, но вы не знаете, сколько строк данных возвращает сервер, а первый столбец не отсортирован по алфавиту.
C1 — это верхняя левая ячейка диапазона (также называемая начальной ячейкой).
Match («апельсины»; C2: C7; 0) ищет оранжевый цвет в диапазоне C2: C7. Не следует включать начальную ячейку в диапазон.
1 — количество столбцов справа от начальной ячейки, для которых должно быть возвращено возвращаемое значение. В нашем примере возвращаемое значение находится в столбце D, Sales.
Поиск значений в списке по горизонтали по точному совпадению
Для выполнения этой задачи используется функция ГПР. Ниже приведен пример.
Функция ГПР выполняет поиск по столбцу Sales и возвращает значение из строки 5 в указанном диапазоне.
Дополнительные сведения можно найти в разделе функции ГПР.
Поиск значений в списке по горизонтали с использованием приблизительного совпадения
Для выполнения этой задачи используется функция ГПР.
Важно: Убедитесь, что значения в первой строке отсортированы в возрастающем порядке.
В приведенном выше примере функция ГПР ищет значение 11000 в строке 3 в указанном диапазоне. Он не находит 11000 и, следовательно, ищет следующее наибольшее значение, которое меньше 1100 и возвращает число 10543.
Дополнительные сведения можно найти в разделе функции ГПР.
Создание формулы подстановки с помощью мастера подстановок (толькоExcel 2007 )
Примечание: Надстройка «Мастер подстановок» прекращена в Excel 2010. Эти функциональные возможности заменены мастером функций и доступными функциями поиска и работы со ссылками (ссылками).
В Excel 2007 мастер подстановок создает формулу подстановки на основе данных листа, имеющих заголовки строк и столбцов. Мастер подстановок помогает находить другие значения в строке, когда вы знаете значение в одном столбце, и наоборот. Мастер подстановок использует индекс и СОВПАДЕНИе в создаваемых формулах.
Щелкните ячейку в диапазоне.
На вкладке формулы в группе решения нажмите кнопку Подстановка .
Если команда подстановка недоступна, необходимо загрузить мастер подстановок надстройка программу.
Загрузка программы-надстройки «Мастер подстановок»
Нажмите кнопку Microsoft Office , щелкните Параметры Excelи выберите категорию надстройки.
В поле Управление выберите элемент Надстройки Excel и нажмите кнопку Перейти.
В диалоговом окне надстройки установите флажок Мастер подстановоки нажмите кнопку ОК.
Выборка значений из таблицы 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);»»)))’ class=’formula’>
Как в Excel выбрать первое минимальное значение кроме нуля:
Как легко заметить, эти формулы отличаются между собой только функциями МИН и МАКС и их аргументами.
Теперь Вас ни что не ограничивает. Один раз разобравшись с принципами действия формул в массиве Вы сможете легко модифицировать их под множество условий и быстро решать много вычислительных задач.
Вывод отобранных значений в отдельный диапазон в Excel. Бесплатные примеры и статьи.
Пять последних значений в MS EXCEL
Найдем, формулу возвращающую ссылку на диапазон, содержащий 5 последних значений. Если столбец со значениями постоянно заполняется, то эта задача перестает быть тривиальной.
Удаляем в MS EXCEL пропуски в списке (формулы)
Если список значений содержит пропуски (пустые ячейки), то это может существенно затруднить его дальнейший анализ. С помощью сортировки уберем пустые ячейки из списка, сформировав формулами список в соседнем столбце.
Запрос на выборку данных (формулы) в MS EXCEL
Суть запроса на выборку – выбрать из исходной таблицы строки, удовлетворяющие определенным критериям (подобно применению стандартного Фильтра). Произведем отбор значений из исходной таблицы с помощью формул массива. В отличие от применения Фильтра (CTRL+SHIFT+L или Данные/ Сортировка и фильтр/ Фильтр ) отобранные строки будут помещены в отдельную таблицу.
Отбор уникальных значений (убираем повторы из списка) в MS EXCEL
Имея список с повторяющимися значениями, создадим список, состоящий только из уникальных значений. При добавлении новых значений в исходный список, список уникальных значений должен автоматически обновляться.
Вывод итогов столбцов по строкам в MS EXCEL
Пусть имеется 5 столбцов с данными. В каждом столбце по 10 чисел, необходимо найти сумму чисел в каждом столбце. Обычно итоговое значение выводится внизу столбца или над его заголовком, поэтому все итоговые значения располагаются в одной строке. Но когда столбцов слишком много, то удобнее итоговые значения столбцов выводить в один отдельный столбец, а не располагать их под данными. Напишем формулу, которая помогает сделать это преобразование.
Отбор неповторяющихся значений со значениями из соседнего столбца в MS EXCEL
Имея список с повторяющимися текстовыми значениями, создадим список, состоящий только из неповторяющихся значений. А из столбца соседнего с исходным, выведем соответствующие им числовые значения.
Отбор неповторяющихся значений в MS EXCEL
Имея список с повторяющимися значениями, создадим список, состоящий только из значений, которые не повторяются.
Отбор повторяющихся значений в MS EXCEL
Из исходной таблицы с повторяющимися значениями отберем только те значения, которые имеют повторы. Теперь при добавлении новых значений в исходный список, новый список будет автоматически содержать только те значения, которые повторяются.
Динамическое разнесение данных по столбцам
Пусть имеется таблица, состоящая из двух столбцов: наименование организации и ее тип (юридическое лицо, индивидуальный предприниматель, физическое лицо). Необходимо разнести организации по разным столбцам в зависимости от типа: Юрлица, ИП и ФЛ должны быть каждый в своем отдельном столбце.При добавлении новых строк в исходную таблицу организации должны динамически попадать в нужный столбец.
Отбор уникальных значений в MS EXCEL с условиями
Продолжим идеи, изложенные в статье Отбор уникальных значений в MS EXCEL. Сначала отберем из таблицы только те строки, которые удовлетворяют заданным условиям, затем из этих строк выберем только уникальные значения из первого столбца. При добавлении новых строк в таблицу, список уникальных значений будет автоматически обновляться.
Запрос на выборку данных в MS EXCEL (на основе элементов управления формы)
Суть запроса на выборку – выбрать из исходной таблицы строки, удовлетворяющие определенным критериям (подобно применению фильтра). В отличие от фильтра отобранные строки будут помещены в отдельную таблицу.
Отбор неповторяющихся значений из двух диапазонов в MS EXCEL
Имея два списка с однотипными повторяющимися значениями, создадим список, состоящий только из неповторяющихся значений.
Отбор уникальных значений из двух диапазонов в MS EXCEL
Имея два списка с однотипными повторяющимися значениями, создадим из них список, содержащий только уникальные значения.
Поиск ТЕКСТовых значений в MS EXCEL с выводом их в отдельный список. Часть2. Подстановочные знаки
Найдем текстовые значения, удовлетворяющие заданному пользователем критерию. Критерии заданы с использованием подстановочных знаков. Поиск будем осуществлять в диапазоне с повторяющимися значениями. При наличии повторов, можно ожидать, что критерию будет соответствовать несколько значений. Для их вывода в отдельный диапазон удобно использовать формулы массива.
Поиск ТЕКСТовых значений в MS EXCEL с выводом их в отдельный список. Часть1. Обычный поиск
Найдем текстовые значения, удовлетворяющие заданному пользователем критерию. Поиск будем осуществлять в диапазоне с повторяющимися значениями. При наличии повторов, можно ожидать, что критерию будет соответствовать несколько значений. Для их вывода в отдельный диапазон удобно использовать формулы массива.
Поиск ТЕКСТовых значений в MS EXCEL с выводом их в отдельный список. Часть3. Поиск с учетом РЕГИСТРА
Найдем текстовые значения, удовлетворяющие заданному пользователем критерию с учетом РЕгиСТРА. Поиск будем осуществлять в диапазоне с повторяющимися значениями. При наличии повторов, можно ожидать, что критерию будет соответствовать несколько значений. Для их вывода в отдельный диапазон удобно использовать формулы массива.
Отбор уникальных значений с сортировкой в MS EXCEL
Из исходной таблицы отберем только уникальные значения и выведем их в отдельный диапазон с сортировкой по возрастанию. Отбор и сортировку сделаем с помощью одной формулой массива. Формула работает как для текстовых (сортировка от А до Я), так и для числовых значений (сортировка от мин до макс).
Поиск ЧИСЛОвых значений и вывод соответствующих значений в отдельный список в MS EXCEL
Найдем числовые значения, равные заданному пользователем критерию. Поиск будем осуществлять в диапазоне с повторяющимися значениями. При наличии повторов, можно ожидать, что критерию будет соответствовать несколько значений. Для их вывода в отдельный диапазон удобно использовать формулы массива.
Поиск нескольких значений с максимальной длиной строки в MS EXCEL
Найдем в исходном списке текстовые значения, которые имеют максимальную длину строки, и выведем их в отдельный диапазон.
Отбор повторяющихся значений (дубликатов) со значениями из соседнего столбца в MS EXCEL
Имея список с повторяющимися текстовыми значениями, создадим список, состоящий только из дубликатов. А из соседнего столбца, выведем соответствующие числовые значения.
ВПР с возвратом всех значений
Все, кто сталкивался с функцией ВПР знают, что она умеет возвращать исключительно одно значений — первое найденное. Но что делать, когда надо видеть все значения? К примеру имеется такая таблица:
И из этой таблицы необходимо получить фамилии(поле ФИО) всех сотрудников из отдела Сбыта:
Тут два варианта:
-
Вариант 1: все значения необходимо получить в одной ячейке через разделитель(скажем запятую). Такое возможно только через использование VBA(на момент написания статьи). Такую функцию я написал давно: Как сцепить несколько значений в одну ячейку по критерию? СцепитьЕсли
. В результате получим что-то вроде: Александров Иван,Александров Петр,Андреев Алексей .
Здесь надо сразу оговориться — при помощи непосредственно ВПР (VLookup) это сделать ну никак не получится. Но это можно сделать при помощи её родственников — связки ИНДЕКС(ПОИСКПОЗ) (INDEX(MATCH)) . Плюс еще пара функций. В сборе функция выглядит так:
=ИНДЕКС( $A$12:$G$111 ;НАИМЕНЬШИЙ(ЕСЛИ( $I$12 = $C$12:$C$111 ;СТРОКА( $C$12:$C$111 )-11);СТРОКА( A1 ));1)
=INDEX($A$12:$G$111;SMALL(IF($I$12=$C$12:$C$111;ROW($C$12:$C$111)-11);ROW(A1));1)
где:
- $A$12:$G$111 — таблица с ФИО и всеми данными
- $I$12 — ячейка с названием отдела
- $C$12:$C$111 — столбец с названиями отделов в таблице $A$12:$G$111
А теперь начнем разбирать формулу по кусочкам
Предлагаю сразу скачать пример файла с данными и формулами — тогда понять будет проще:
Tips_All_VlookupAllVals.xls (84,5 KiB, 8 651 скачиваний)
- Первое и самое главное — формула вводится в ячейку как формула массива. Это значит, что для приложенного к статье примера необходимо будет выделить ячейку J12 , записать в неё формулу и завершить ввод нажатием сразу трех клавиш: Ctrl+Shift+Enter. После этого скопировать ячейку, выделить диапазон J13:J39 и вставить туда скопированную ячейку.
- За отбор ФИО указанного отдела отвечает этот кусок: ЕСЛИ( $I$12 = $C$12:$C$111 ;СТРОКА( $C$12:$C$111 )-11)
IF($I$12=$C$12:$C$111;ROW($C$12:$C$111)-11)
Как видно здесь идет сравнение отдела, записанного в $I$12 со всеми отделами в таблице: $C$12:$C$111 . Если отдел совпадает, то функция возвращает номер строки СТРОКА( $C$12:$C$111 ) . Но нам нужен не номер строки на листе, а номер строки внутри таблицы(потому что в формулу ИНДЕКС (INDEX) у нас передан диапазон $A$12:$G$111 и если передать в его второй аргумент( номер_строки ) 14, то получим не Александров Иван , а Андреев Олег ). Поэтому отнимаем от номера строки 11, чтобы было возвращено число 3(а не 14). Т.к. формула записана формулой массива — ЕСЛИ (IF) возвращает массив из номеров строк и логического ЛОЖЬ (FALSE) (если отдел не совпадает):
шаг 1: ЕСЛИ(<ЛОЖЬ:ЛОЖЬ: ИСТИНА :ЛОЖЬ:ЛОЖЬ: ИСТИНА :ЛОЖЬ:ЛОЖЬ:ЛОЖЬ>;<12:13: 14 :15:16: 17 :18:19:20>-11)
шаг 2: ЕСЛИ(<ЛОЖЬ:ЛОЖЬ: ИСТИНА :ЛОЖЬ:ЛОЖЬ: ИСТИНА :ЛОЖЬ:ЛОЖЬ:ЛОЖЬ>;<1:2: 3 :4:5: 6 :7:8:9>)
шаг 3: - Т.к. ЕСЛИ (IF) в данном случае возвращает массив значений, включая ненужные нам ЛОЖЬ (FALSE) — применяем НАИМЕНЬШИЙ (SMALL) , которая будет брать только числа (сначала 3, затем 6 и т.д.), а логические значения ЛОЖЬ (FALSE) будет игнорировать:
НАИМЕНЬШИЙ(<ЛОЖЬ:ЛОЖЬ: 3 :ЛОЖЬ:ЛОЖЬ: 6 :ЛОЖЬ:ЛОЖЬ:ЛОЖЬ>;СТРОКА(A1))
SMALL(<ЛОЖЬ:ЛОЖЬ: 3 :ЛОЖЬ:ЛОЖЬ: 6 :ЛОЖЬ:ЛОЖЬ:ЛОЖЬ>;ROW(A1))
Функция НАИМЕНЬШИЙ (SMALL) отбирает из указанного массива чисел наименьшее. При этом можно отобрать по рангу — первое наименьшее, второе наименьшее, третье наименьшее и т.д.
- с первым аргументом разобрались — это уже отобранные записи, где число — строка в таблице с нужной ФИО и ненужные нам логические ЛОЖЬ (FALSE) .
- второй аргумент СТРОКА(A1) для каждой следующей строки будет меняться. В приложенном примере первая ячейка с формулой — J12 . В ней СТРОКА(A1) равна 1, т.е. НАИМЕНЬШИЙ (SMALL) вернет первое наименьшее из массива чисел — 3 . В ячейке J13 это уже будет СТРОКА(A2) и она равна 2, а значит НАИМЕНЬШИЙ (SMALL) вернет второе наименьшее из массива чисел — 6 . И т.д. Когда все числа закончатся — НАИМЕНЬШИЙ (SMALL) вернет значение ошибки #ЧИСЛО! (#NUM!)
ячейка J12
шаг 1: НАИМЕНЬШИЙ(<ЛОЖЬ:ЛОЖЬ: 3 :ЛОЖЬ:ЛОЖЬ: 6 :ЛОЖЬ:ЛОЖЬ:ЛОЖЬ>;СТРОКА(A1))
шаг 2: НАИМЕНЬШИЙ(<ЛОЖЬ:ЛОЖЬ: 3 :ЛОЖЬ:ЛОЖЬ: 6 :ЛОЖЬ:ЛОЖЬ:ЛОЖЬ>;1)
шаг 3: НАИМЕНЬШИЙ( 3 )
ячейка J13
шаг 1: НАИМЕНЬШИЙ(<ЛОЖЬ:ЛОЖЬ: 3 :ЛОЖЬ:ЛОЖЬ: 6 :ЛОЖЬ:ЛОЖЬ:ЛОЖЬ>;СТРОКА(A2))
шаг 2: НАИМЕНЬШИЙ(<ЛОЖЬ:ЛОЖЬ: 3 :ЛОЖЬ:ЛОЖЬ: 6 :ЛОЖЬ:ЛОЖЬ:ЛОЖЬ>;2)
шаг 3: НАИМЕНЬШИЙ( 6 )
ячейка J12
шаг 1: =ИНДЕКС( $A$12:$G$111 ;НАИМЕНЬШИЙ( 3 );1)
шаг 2: =ИНДЕКС( $A$12:$G$111 ;3;1)
шаг 3: Александров Иван
ячейка J13
шаг 1: =ИНДЕКС( $A$12:$G$111 ;НАИМЕНЬШИЙ( 6 );1)
шаг 2: =ИНДЕКС( $A$12:$G$111 ;6;1)
шаг 3: Александров Петр
И в довершение неплохо бы убрать ошибку в случае, если ни одно значение не соответствует критерию или значений больше, чем ячеек с формулами. Более подробно подобное решение я описывал в этой статье: Как в ячейке с формулой вместо ошибки показать 0
Для всех версий Excel:
=ЕСЛИ(ЕОШ(ИНДЕКС( $A$12:$G$111 ;НАИМЕНЬШИЙ(ЕСЛИ( $I$12 = $C$12:$C$111 ;СТРОКА( $C$12:$C$111 )-11);СТРОКА( A1 ));1));»»;ИНДЕКС( $A$12:$G$111 ;НАИМЕНЬШИЙ(ЕСЛИ( $I$12 = $C$12:$C$111 ;СТРОКА( $C$12:$C$111 )-11);СТРОКА( A1 ));1))
=IF(ISERR(INDEX($A$12:$G$111;SMALL(IF($I$12=$C$12:$C$111;ROW($C$12:$C$111)-11);ROW(A1));1));»»;INDEX($A$12:$G$111;SMALL(IF($I$12=$C$12:$C$111;ROW($C$12:$C$111)-11);ROW(A1));1))
Для Excel 2007 и выше:
=ЕСЛИОШИБКА(ИНДЕКС( $A$12:$G$111 ;НАИМЕНЬШИЙ(ЕСЛИ( $I$12 = $C$12:$C$111 ;СТРОКА( $C$12:$C$111 )-11);СТРОКА( A1 ));1);»»)
=IFERROR(INDEX($A$12:$G$111;SMALL(IF($I$12=$C$12:$C$111;ROW($C$12:$C$111)-11);ROW(A1));1);»»)
Плюс к этому в приложенном к статье файле я привел формулу, которая возвращает список всех сотрудников выбранного отдела без повторений и формулу с возможностью просто поменять заголовок в результирующем столбце(в файле это столбец K, ячейка K11 ) на любой из исходной таблицы и данные будут отображены из этого столбца.
Например, если вместо столбца ФИО записать в K11 Адрес — будут отображены все адреса сотрудников выбранного отдела. Если записать Телефон — все телефоны сотрудников выбранного отдела.
Tips_All_VlookupAllVals.xls (84,5 KiB, 8 651 скачиваний)
Статья помогла? Поделись ссылкой с друзьями!
Поиск и подстановка по нескольким условиям
Постановка задачи
Если вы продвинутый пользователь 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 и т.д.) Многим непривычны формулы массива в принципе (тогда вам сюда).
Совет: Попробуйте использовать новые функции ПРОСМОТРX и XMATCH, а также улучшенные версии функций, описанные в этой статье. Эти новые функции работают в любом направлении и возвращают точные совпадения по умолчанию, что упрощает и упрощает работу с ними по сравнению с предшественниками.
Предположим, у вас есть список номеров офисов, и вам нужно знать, какие сотрудники работают в каждом из них. Таблица очень угрюмая, поэтому, возможно, вам кажется, что это сложная задача. С функцией подытов на самом деле это довольно просто.
Функции ВВ., а также ИНДЕКС и ВЫБОРПОЗ — одни из самых полезных функций в Excel.
Примечание: Мастер подметок больше не доступен в Excel.
Ниже в качестве примера по выбору вы можете найти пример использования в этой области.
=ВПР(B2;C2:E7,3,ИСТИНА)
В этом примере B2 является первым аргументом —элементом данных, который требуется для работы функции. В случае СРОТ ВЛ.В.ОВ этот первый аргумент является искомой значением. Этот аргумент может быть ссылкой на ячейку или фиксированным значением, таким как «кузьмина» или 21 000. Вторым аргументом является диапазон ячеек C2–:E7, в котором нужно найти и найти значение. Третий аргумент — это столбец в диапазоне ячеек, содержащий ищите значение.
Четвертый аргумент необязателен. Введите истина или ЛОЖЬ. Если ввести ИСТИНА или оставить аргумент пустым, функция возвращает приблизительное совпадение значения, указанного в качестве первого аргумента. Если ввести ЛОЖЬ, функция будет соответствовать значению, заведомо первому аргументу. Другими словами, если оставить четвертый аргумент пустым или ввести ИСТИНА, это обеспечивает большую гибкость.
В этом примере показано, как работает функция. При вводе значения в ячейку B2 (первый аргумент) в результате поиска в ячейках диапазона C2:E7 (2-й аргумент) выполняется поиск в ней и возвращается ближайшее приблизительное совпадение из третьего столбца в диапазоне — столбца E (третий аргумент).
Четвертый аргумент пуст, поэтому функция возвращает приблизительное совпадение. Иначе потребуется ввести одно из значений в столбец C или D, чтобы получить какой-либо результат.
Если вы хорошо разучились работать с функцией ВГТ.В.В., то в равной степени использовать ее будет легко. Вы вводите те же аргументы, но выполняется поиск в строках, а не в столбцах.
Использование индекса и MATCH вместо ВРОТ
При использовании функции ВПРАВО существует ряд ограничений, которые действуют только при использовании функции ВПРАВО. Это означает, что столбец, содержащий и look up, всегда должен быть расположен слева от столбца, содержащего возвращаемого значения. Теперь, если ваша таблица не построена таким образом, не используйте В ПРОСМОТР. Используйте вместо этого сочетание функций ИНДЕКС и MATCH.
В данном примере представлен небольшой список, в котором искомое значение (Воронеж) не находится в крайнем левом столбце. Поэтому мы не можем использовать функцию ВПР. Для поиска значения «Воронеж» в диапазоне B1:B11 будет использоваться функция ПОИСКПОЗ. Оно найдено в строке 4. Затем функция ИНДЕКС использует это значение в качестве аргумента поиска и находит численность населения Воронежа в четвертом столбце (столбец D). Использованная формула показана в ячейке A14.
Дополнительные примеры использования индексов и MATCH вместо В ПРОСМОТР см. в статье билла Https://www.mrexcel.com/excel-tips/excel-vlookup-index-match/ Билла Джилена (Bill Jelen), MVP корпорации Майкрософт.
Попробуйте попрактиковаться
Если вы хотите поэкспериментировать с функциями подытовки, прежде чем попробовать их с собственными данными, вот примеры данных.
Пример работы с ВЛОКОНПОМ
Скопируйте следующие данные в пустую таблицу.
Совет: Прежде чем врезать данные в Excel, установите для столбцов A–C ширину в 250 пикселей и нажмите кнопку «Перенос текста» (вкладка «Главная», группа «Выравнивание»).
Плотность |
Вязкость |
Температура |
0,457 |
3,55 |
500 |
0,525 |
3,25 |
400 |
0,606 |
2,93 |
300 |
0,675 |
2,75 |
250 |
0,746 |
2,57 |
200 |
0,835 |
2,38 |
150 |
0,946 |
2,17 |
100 |
1,09 |
1,95 |
50 |
1,29 |
1,71 |
0 |
Формула |
Описание |
Результат |
=ВПР(1,A2:C10,2) |
Используя приблизительное соответствие, функция ищет в столбце A значение 1, находит наибольшее значение, которое меньше или равняется 1 и составляет 0,946, а затем возвращает значение из столбца B в той же строке. |
2,17 |
=ВПР(1,A2:C10,3,ИСТИНА) |
Используя приблизительное соответствие, функция ищет в столбце A значение 1, находит наибольшее значение, которое меньше или равняется 1 и составляет 0,946, а затем возвращает значение из столбца C в той же строке. |
100 |
=ВПР(0,7,A2:C10,3,ЛОЖЬ) |
Используя точное соответствие, функция ищет в столбце A значение 0,7. Поскольку точного соответствия нет, возвращается сообщение об ошибке. |
#Н/Д |
=ВПР(0,1,A2:C10,2,ИСТИНА) |
Используя приблизительное соответствие, функция ищет в столбце A значение 0,1. Поскольку 0,1 меньше наименьшего значения в столбце A, возвращается сообщение об ошибке. |
#Н/Д |
=ВПР(2,A2:C10,2,ИСТИНА) |
Используя приблизительное соответствие, функция ищет в столбце A значение 2, находит наибольшее значение, которое меньше или равняется 2 и составляет 1,29, а затем возвращает значение из столбца B в той же строке. |
1,71 |
Пример ГВ.Г.В.В.
Скопируйте всю таблицу и вставьте ее в ячейку A1 пустого листа Excel.
Совет: Прежде чем врезать данные в Excel, установите для столбцов A–C ширину в 250 пикселей и нажмите кнопку «Перенос текста» (вкладка «Главная», группа «Выравнивание»).
Оси |
Подшипники |
Болты |
4 |
4 |
9 |
5 |
7 |
10 |
6 |
8 |
11 |
Формула |
Описание |
Результат |
=ГПР(«Оси»;A1:C4;2;ИСТИНА) |
Поиск слова «Оси» в строке 1 и возврат значения из строки 2, находящейся в том же столбце (столбец A). |
4 |
=ГПР(«Подшипники»;A1:C4;3;ЛОЖЬ) |
Поиск слова «Подшипники» в строке 1 и возврат значения из строки 3, находящейся в том же столбце (столбец B). |
7 |
=ГПР(«П»;A1:C4;3;ИСТИНА) |
Поиск буквы «П» в строке 1 и возврат значения из строки 3, находящейся в том же столбце. Так как «П» найти не удалось, возвращается ближайшее из меньших значений: «Оси» (в столбце A). |
5 |
=ГПР(«Болты»;A1:C4;4) |
Поиск слова «Болты» в строке 1 и возврат значения из строки 4, находящейся в том же столбце (столбец C). |
11 |
=ГПР(3;{1;2;3:»a»;»b»;»c»;»d»;»e»;»f»};2;ИСТИНА) |
Поиск числа 3 в трех строках константы массива и возврат значения из строки 2 того же (в данном случае — третьего) столбца. Константа массива содержит три строки значений, разделенных точкой с запятой (;). Так как «c» было найдено в строке 2 того же столбца, что и 3, возвращается «c». |
c |
Примеры индекса и match
В последнем примере функции ИНДЕКС и MATCH совместно возвращают номер счета с наиболее ранней датой и соответствующую дату для каждого из пяти городов. Так как дата возвращается как число, для ее формата используется функция ТЕКСТ. Функция ИНДЕКС использует результат, возвращенный функцией ПОИСКПОЗ, как аргумент. Сочетание функций ИНДЕКС и ПОИСКПОЗ используется в каждой формуле дважды — сперва для возврата номера счета, а затем для возврата даты.
Скопируйте всю таблицу и вставьте ее в ячейку A1 пустого листа Excel.
Совет: Перед тем как вировать данные в Excel, установите для столбцов A–D ширину в 250 пикселей и нажмите кнопку «Перенос текста» (вкладка «Главная», группа «Выравнивание»).
Счет |
Город |
Дата выставления счета |
Счет с самой ранней датой по городу, с датой |
3115 |
Казань |
07.04.12 |
=»Казань = «&ИНДЕКС($A$2:$C$33,ПОИСКПОЗ(«Казань»,$B$2:$B$33,0),1)& «, Дата выставления счета: » & ТЕКСТ(ИНДЕКС($A$2:$C$33,ПОИСКПОЗ(«Казань»,$B$2:$B$33,0),3),»m/d/yy») |
3137 |
Казань |
09.04.12 |
=»Орел = «&ИНДЕКС($A$2:$C$33,ПОИСКПОЗ(«Орел»,$B$2:$B$33,0),1)& «, Дата выставления счета: » & ТЕКСТ(ИНДЕКС($A$2:$C$33,ПОИСКПОЗ(«Орел»,$B$2:$B$33,0),3),»m/d/yy») |
3154 |
Казань |
11.04.12 |
=»Челябинск = «&ИНДЕКС($A$2:$C$33,ПОИСКПОЗ(«Челябинск»,$B$2:$B$33,0),1)& «, Дата выставления счета: » & ТЕКСТ(ИНДЕКС($A$2:$C$33,ПОИСКПОЗ(«Челябинск»,$B$2:$B$33,0),3),»m/d/yy») |
3191 |
Казань |
21.04.12 |
=»Нижний Новгород = «&ИНДЕКС($A$2:$C$33,ПОИСКПОЗ(«Нижний Новгород»,$B$2:$B$33,0),1)& «, Дата выставления счета: » & ТЕКСТ(ИНДЕКС($A$2:$C$33,ПОИСКПОЗ(«Нижний Новгород»,$B$2:$B$33,0),3),»m/d/yy») |
3293 |
Казань |
25.04.12 |
=»Москва = «&ИНДЕКС($A$2:$C$33,ПОИСКПОЗ(«Москва»,$B$2:$B$33,0),1)& «, Дата выставления счета: » & ТЕКСТ(ИНДЕКС($A$2:$C$33,ПОИСКПОЗ(«Москва»,$B$2:$B$33,0),3),»m/d/yy») |
3331 |
Казань |
27.04.12 |
|
3350 |
Казань |
28.04.12 |
|
3390 |
Казань |
01.05.12 |
|
3441 |
Казань |
02.05.12 |
|
3517 |
Казань |
08.05.12 |
|
3124 |
Орел |
09.04.12 |
|
3155 |
Орел |
11.04.12 |
|
3177 |
Орел |
19.04.12 |
|
3357 |
Орел |
28.04.12 |
|
3492 |
Орел |
06.05.12 |
|
3316 |
Челябинск |
25.04.12 |
|
3346 |
Челябинск |
28.04.12 |
|
3372 |
Челябинск |
01.05.12 |
|
3414 |
Челябинск |
01.05.12 |
|
3451 |
Челябинск |
02.05.12 |
|
3467 |
Челябинск |
02.05.12 |
|
3474 |
Челябинск |
04.05.12 |
|
3490 |
Челябинск |
05.05.12 |
|
3503 |
Челябинск |
08.05.12 |
|
3151 |
Нижний Новгород |
09.04.12 |
|
3438 |
Нижний Новгород |
02.05.12 |
|
3471 |
Нижний Новгород |
04.05.12 |
|
3160 |
Москва |
18.04.12 |
|
3328 |
Москва |
26.04.12 |
|
3368 |
Москва |
29.04.12 |
|
3420 |
Москва |
01.05.12 |
|
3501 |
Москва |
06.05.12 |
Во второй части нашего учебника по функции ВПР (VLOOKUP) в Excel мы разберём несколько примеров, которые помогут Вам направить всю мощь ВПР на решение наиболее амбициозных задач Excel.
Примеры подразумевают, что Вы уже имеете базовые знания о том, как работает эта функция. Если нет, возможно, Вам будет интересно начать с первой части этого учебника, в которой объясняются синтаксис и основное применение ВПР.
Что ж, давайте приступим.
Поиск в Excel по нескольким критериям
Функция ВПР в Excel – это действительно мощный инструмент для выполнения поиска определённого значения в базе данных. Однако, есть существенное ограничение – её синтаксис позволяет искать только одно значение. Как же быть, если требуется выполнить поиск по нескольким условиям? Решение Вы найдёте далее.
Пример 1: Поиск по 2-м разным критериям
Предположим, у нас есть список заказов и мы хотим найти Количество товара (Qty.), основываясь на двух критериях – Имя клиента (Customer) и Название продукта (Product). Дело усложняется тем, что каждый из покупателей заказывал несколько видов товаров, как это видно из таблицы ниже:
- Обычная функция ВПР не будет работать по такому сценарию, поскольку она возвратит первое найденное значение, соответствующее заданному искомому значению. Например, если Вы хотите узнать количество товара Sweets, заказанное покупателем Jeremy Hill, запишите вот такую формулу:
- =VLOOKUP(B1,$A$5:$C$14,3,FALSE)
=ВПР(B1;$A$5:$C$14;3;ЛОЖЬ) - – эта формула вернет результат 15, соответствующий товару Apples, так как это первое совпадающее значение.
Есть простой обходной путь – создать дополнительный столбец, в котором объединить все нужные критерии.
В нашем примере это столбцы Имя клиента (Customer) и Название продукта (Product).
Не забывайте, что объединенный столбец должен быть всегда крайним левым в диапазоне поиска, поскольку именно левый столбец функция ВПР просматривает при поиске значения.
Итак, Вы добавляете вспомогательный столбец в таблицу и копируете по всем его ячейкам формулу вида: =B2&C2. Если хочется, чтобы строка была более читаемой, можно разделить объединенные значения пробелом: =B2&” “&C2. После этого можно использовать следующую формулу:
- =VLOOKUP(«Jeremy Hill Sweets»,$A$7:$D$18,4,FALSE)
=ВПР(«Jeremy Hill Sweets»;$A$7:$D$18;4;ЛОЖЬ) - или
- =VLOOKUP(B1,$A$7:$D$18,4,FALSE)
=ВПР(B1;$A$7:$D$18;4;ЛОЖЬ)
Где ячейка B1 содержит объединенное значение аргумента lookup_value (искомое_значение), а 4 – аргумент col_index_num (номер_столбца), т.е. номер столбца, содержащего данные, которые необходимо извлечь.
Пример 2: ВПР по двум критериям с просматриваемой таблицей на другом листе
Если Вам необходимо обновить основную таблицу (Main table), добавив данные из второй таблицы (Lookup table), которая находится на другом листе или в другой рабочей книге Excel, то Вы можете собрать искомое значение непосредственно в формуле, которую вставляете в основную таблицу.
Как и в предыдущем примере, Вам понадобится в таблице поиска (Lookup table) вспомогательный столбец с объединенными значениями. Этот столбец должен быть крайним левым в заданном для поиска диапазоне.
Итак, формула с ВПР может быть такой:
=VLOOKUP(B2&» «&C2,Orders!$A&$2:$D$2,4,FALSE)
=ВПР(B2&» «&C2;Orders!$A&$2:$D$2;4;ЛОЖЬ)
Здесь в столбцах B и C содержатся имена клиентов и названия продуктов соответственно, а ссылка Orders!$A&$2:$D$2 определяет таблицу для поиска на другом листе.
Чтобы сделать формулу более читаемой, Вы можете задать имя для просматриваемого диапазона, и тогда формула станет выглядеть гораздо проще:
=VLOOKUP(B2&» «&C2,Orders,4,FALSE)
=ВПР(B2&» «&C2;Orders;4;ЛОЖЬ)
Чтобы формула работала, значения в крайнем левом столбце просматриваемой таблицы должны быть объединены точно так же, как и в критерии поиска. На рисунке выше мы объединили значения и поставили между ними пробел, точно так же необходимо сделать в первом аргументе функции (B2&” “&C2).
Запомните! Функция ВПР ограничена 255 символами, она не может искать значение, состоящее из более чем 255 символов. Имейте это ввиду и следите, чтобы длина искомого значения не превышала этот лимит.
Соглашусь, добавление вспомогательного столбца – не самое изящное и не всегда приемлемое решение. Вы можете сделать то же самое без вспомогательного столбца, но в таком случае потребуется гораздо более сложная формула с комбинацией функций INDEX (ИНДЕКС) и MATCH (ПОИСКПОЗ).
Извлекаем 2-е, 3-е и т.д. значения, используя ВПР
Вы уже знаете, что ВПР может возвратить только одно совпадающее значение, точнее – первое найденное. Но как быть, если в просматриваемом массиве это значение повторяется несколько раз, и Вы хотите извлечь 2-е или 3-е из них? А что если все значения? Задачка кажется замысловатой, но решение существует!
Предположим, в одном столбце таблицы записаны имена клиентов (Customer Name), а в другом – товары (Product), которые они купили. Попробуем найти 2-й, 3-й и 4-й товары, купленные заданным клиентом.
Простейший способ – добавить вспомогательный столбец перед столбцом Customer Name и заполнить его именами клиентов с номером повторения каждого имени, например, John Doe1, John Doe2 и т.д. Фокус с нумерацией сделаем при помощи функции COUNTIF (СЧЁТЕСЛИ), учитывая, что имена клиентов находятся в столбце B:
=B2&COUNTIF($B$2:B2,B2)
=B2&СЧЁТЕСЛИ($B$2:B2;B2)
После этого Вы можете использовать обычную функцию ВПР, чтобы найти нужный заказ. Например:
- Находим 2-й товар, заказанный покупателем Dan Brown:
=VLOOKUP(«Dan Brown2»,$A$2:$C$16,3,FALSE)
=ВПР(«Dan Brown2»;$A$2:$C$16;3;ЛОЖЬ) - Находим 3-й товар, заказанный покупателем Dan Brown:
=VLOOKUP(«Dan Brown3»,$A$2:$C$16,3,FALSE)
=ВПР(«Dan Brown3»;$A$2:$C$16;3;ЛОЖЬ)
На самом деле, Вы можете ввести ссылку на ячейку в качестве искомого значения вместо текста, как представлено на следующем рисунке:
- Если Вы ищите только 2-е повторение, то можете сделать это без вспомогательного столбца, создав более сложную формулу:
- =IFERROR(VLOOKUP($F$2,INDIRECT(«$B$»&(MATCH($F$2,Table4[Customer Name],0)+2)&»:$C16″),2,FALSE),»»)
=ЕСЛИОШИБКА(ВПР($F$2;ДВССЫЛ(«$B$»&(ПОИСКПОЗ($F$2;Table4[Customer Name];0)+2)&»:$C16″);2;ИСТИНА);»») - В этой формуле:
- $F$2 – ячейка, содержащая имя покупателя (она неизменна, обратите внимание – ссылка абсолютная);
- $B$ – столбец Customer Name;
- Table4 – Ваша таблица (на этом месте также может быть обычный диапазон);
- $C16 – конечная ячейка Вашей таблицы или диапазона.
Эта формула находит только второе совпадающее значение. Если же Вам необходимо извлечь остальные повторения, воспользуйтесь предыдущим решением.
Если Вам нужен список всех совпадений – функция ВПР тут не помощник, поскольку она возвращает только одно значение за раз – и точка. Но в Excel есть функция INDEX (ИНДЕКС), которая с легкостью справится с этой задачей. Как будет выглядеть такая формула, Вы узнаете в следующем примере.
Извлекаем все повторения искомого значения
- Как упоминалось выше, ВПР не может извлечь все повторяющиеся значения из просматриваемого диапазона.
Чтобы сделать это, Вам потребуется чуть более сложная формула, составленная из нескольких функций Excel, таких как INDEX (ИНДЕКС), SMALL (НАИМЕНЬШИЙ) и ROW (СТРОКА)
- Например, формула, представленная ниже, находит все повторения значения из ячейки F2 в диапазоне B2:B16 и возвращает результат из тех же строк в столбце C.
- {=IFERROR(INDEX($C$2:$C$16,SMALL(IF($F$2=B2:B16,ROW(C2:C16)-1,»»),ROW()-3)),»»)}
{=ЕСЛИОШИБКА(ИНДЕКС($C$2:$C$16;НАИМЕНЬШИЙ(ЕСЛИ($F$2=B2:B16;СТРОКА(C2:C16)-1;»»);СТРОКА()-3));»»)}
Введите эту формулу массива в несколько смежных ячеек, например, в ячейки F4:F8, как показано на рисунке ниже. Количество ячеек должно быть равным или большим, чем максимально возможное число повторений искомого значения. Не забудьте нажать Ctrl+Shift+Enter, чтобы правильно ввести формулу массива.
Если Вам интересно понять, как она работает, давайте немного погрузимся в детали формулы:
Часть 1:
IF($F$2=B2:B16,ROW(C2:C16)-1,»»)
ЕСЛИ($F$2=B2:B16;СТРОКА(C2:C16)-1;»»)
$F$2=B2:B16 – сравниваем значение в ячейке F2 с каждым из значений диапазона B2:B16. Если найдено совпадение, то выражение СТРОКА(C2:C16)-1 возвращает номер соответствующей строки (значение -1 позволяет не включать строку заголовков). Если совпадений нет, функция IF (ЕСЛИ) возвращает пустую строку.
Результатом функции IF (ЕСЛИ) окажется вот такой горизонтальный массив: {1,»»,3,»»,5,»»,»»,»»,»»,»»,»»,12,»»,»»,»»}
Часть 2:
ROW()-3
СТРОКА()-3
Здесь функция ROW (СТРОКА) действует как дополнительный счётчик. Так как формула скопирована в ячейки F4:F9, мы вычитаем число 3 из результата функции, чтобы получить значение 1 в ячейке F4 (строка 4, вычитаем 3), чтобы получить 2 в ячейке F5 (строка 5, вычитаем 3) и так далее.
Часть 3:
SMALL(IF($F$2=B2:B16,ROW(C2:C16)-1,»»),ROW()-3))
НАИМЕНЬШИЙ(ЕСЛИ($F$2=B2:B16;СТРОКА(C2:C16)-1;»»);СТРОКА()-3))
Функция SMALL (НАИМЕНЬШИЙ) возвращает n-ое наименьшее значение в массиве данных. В нашем случае, какую по счёту позицию (от наименьшего) возвращать – определено функцией ROW (СТРОКА) (смотри Часть 2).
Так, для ячейки F4 функция НАИМЕНЬШИЙ({массив};1) возвращает 1-й (наименьший) элемент массива, то есть 1.
Для ячейки F5 возвращает 2-й наименьший элемент массива, то есть 3, и так далее.
Часть 4:
INDEX($C$2:$C$16,SMALL(IF($F$2=B2:B16,ROW(C2:C16)-1,»»),ROW()-3))
ИНДЕКС($C$2:$C$16;НАИМЕНЬШИЙ(ЕСЛИ($F$2=B2:B16;СТРОКА(C2:C16)-1;»»);СТРОКА()-3))
Функция INDEX (ИНДЕКС) просто возвращает значение определённой ячейки в массиве C2:C16. Для ячейки F4 функция ИНДЕКС($C$2:$C$16;1) возвратит Apples, для F5 функция ИНДЕКС($C$2:$C$16;3) возвратит Sweets и так далее.
Часть 5:
IFERROR()
ЕСЛИОШИБКА()
В завершение, мы помещаем формулу внутрь функции IFERROR (ЕСЛИОШИБКА), поскольку вряд ли Вас обрадует сообщение об ошибке #N/A (#Н/Д) в случае, если количество ячеек, в которые скопирована формула, будет меньше, чем количество повторяющихся значений в просматриваемом диапазоне.
Двумерный поиск по известным строке и столбцу
Выполнение двумерного поиска в Excel подразумевает поиск значения по известному номеру строки и столбца. Другими словами, Вы извлекаете значение ячейки на пересечении конкретной строки и столбца.
Итак, давайте обратимся к нашей таблице и запишем формулу с функцией ВПР, которая найдет информацию о стоимости проданных в марте лимонов.
Существует несколько способов выполнить двумерный поиск. Познакомьтесь с возможными вариантами и выберите наиболее подходящий.
Функции ВПР и ПОИСКПОЗ
Вы можете использовать связку из функций ВПР (VLOOKUP) и ПОИСКПОЗ (MATCH), чтобы найти значение на пересечении полей Название продукта (строка) и Месяц (столбец) рассматриваемого массива:
=VLOOKUP(«Lemons»,$A$2:$I$9,MATCH(«Mar»,$A$1:$I$1,0),FALSE)
=ВПР(«Lemons»;$A$2:$I$9;ПОИСКПОЗ(«Mar»;$A$1:$I$1;0);ЛОЖЬ)
Формула выше – это обычная функция ВПР, которая ищет точное совпадение значения “Lemons” в ячейках от A2 до A9. Но так как Вы не знаете, в каком именно столбце находятся продажи за март, то не сможете задать номер столбца для третьего аргумента функции ВПР. Вместо этого используется функция ПОИСКПОЗ, чтобы определить этот столбец.
MATCH(«Mar»,$A$1:$I$1,0)
ПОИСКПОЗ(«Mar»;$A$1:$I$1;0)
В переводе на человеческий язык, данная формула означает:
- Ищем символы “Mar” – аргумент lookup_value (искомое_значение);
- Ищем в ячейках от A1 до I1 – аргумент lookup_array (просматриваемый_массив);
- Возвращаем точное совпадение – аргумент match_type (тип_сопоставления).
Использовав в третьем аргументе, Вы говорите функции ПОИСКПОЗ искать первое значение, в точности совпадающее с искомым значением. Это равносильно значению FALSE (ЛОЖЬ) для четвёртого аргумента ВПР.
Вот так Вы можете создать формулу для поиска по двум критериям в Excel, что также известно, как двумерный поиск или поиск в двух направлениях.
Функция СУММПРОИЗВ
Функция СУММПРОИЗВ (SUMPRODUCT) возвращает сумму произведений выбранных массивов:
=SUMPRODUCT(($A$2:$A$9=»Lemons»)*($A$1:$I$1=»Mar»),$A$2:$I$9)
=СУММПРОИЗВ(($A$2:$A$9=»Lemons»)*($A$1:$I$1=»Mar»);$A$2:$I$9)
Функции ИНДЕКС и ПОИСКПОЗ
В следующей статье я буду объяснять эти функции во всех деталях, так что сейчас можете просто скопировать эту формулу:
=INDEX($A$2:$I$9,MATCH(«Lemons»,$A$2:$A$9,0),MATCH(«Mar»,$A$1:$I$1,0))
=ИНДЕКС($A$2:$I$9;ПОИСКПОЗ(«Lemons»;$A$2:$A$9;0);ПОИСКПОЗ(«Mar»;$A$1:$I$1;0))
Именованные диапазоны и оператор пересечения
Если Вы не в восторге от всех этих сложных формул Excel, Вам может понравиться вот такой наглядный и запоминающийся способ:
- Выделите таблицу, откройте вкладку Formulas (Формулы) и нажмите Create from Selection (Создать из выделенного).
- Отметьте галочками Top row (в строке выше) и Left column (в столбце слева). Microsoft Excel назначит имена диапазонам из значений в верхней строке и левом столбце Вашей таблицы. Теперь Вы можете осуществлять поиск, используя эти имена, напрямую, без создания формул.
- В любой пустой ячейке запишите =имя_строки имя_столбца, например, так:
=Lemons Mar
… или наоборот:=Mar Lemons
Источник: https://office-guru.ru/excel/prodvinutye-primery-s-funkciei-vpr-167.html
Выборка данных в Microsoft Excel
При работе с таблицами Excel довольно часто приходится проводить отбор в них по определенному критерию или по нескольким условиям. В программе сделать это можно различными способами при помощи ряда инструментов. Давайте выясним, как произвести выборку в Экселе, используя разнообразные варианты.
Выполнение выборки
Выборка данных состоит в процедуре отбора из общего массива тех результатов, которые удовлетворяют заданным условиям, с последующим выводом их на листе отдельным списком или в исходном диапазоне.
Способ 1: применение расширенного автофильтра
Наиболее простым способом произвести отбор является применение расширенного автофильтра. Рассмотрим, как это сделать на конкретном примере.
- Выделяем область на листе, среди данных которой нужно произвести выборку. Во вкладке «Главная» щелкаем по кнопке «Сортировка и фильтр». Она размещается в блоке настроек «Редактирование». В открывшемся после этого списка выполняем щелчок по кнопке «Фильтр».
Есть возможность поступить и по-другому. Для этого после выделения области на листе перемещаемся во вкладку «Данные». Щелкаем по кнопке «Фильтр», которая размещена на ленте в группе «Сортировка и фильтр».
- После этого действия в шапке таблицы появляются пиктограммы для запуска фильтрования в виде перевернутых острием вниз небольших треугольников на правом краю ячеек. Кликаем по данному значку в заглавии того столбца, по которому желаем произвести выборку. В запустившемся меню переходим по пункту «Текстовые фильтры». Далее выбираем позицию «Настраиваемый фильтр…».
- Активируется окно пользовательской фильтрации. В нем можно задать ограничение, по которому будет производиться отбор. В выпадающем списке для столбца содержащего ячейки числового формата, который мы используем для примера, можно выбрать одно из пяти видов условий:
- равно;
- не равно;
- больше;
- больше или равно;
- меньше.
Давайте в качестве примера зададим условие так, чтобы отобрать только значения, по которым сумма выручки превышает 10000 рублей. Устанавливаем переключатель в позицию «Больше». В правое поле вписываем значение «10000». Чтобы произвести выполнение действия, щелкаем по кнопке «OK».
- Как видим, после фильтрации остались только строчки, в которых сумма выручки превышает 10000 рублей.
- Но в этом же столбце мы можем добавить и второе условие. Для этого опять возвращаемся в окно пользовательской фильтрации. Как видим, в его нижней части есть ещё один переключатель условия и соответствующее ему поле для ввода. Давайте установим теперь верхнюю границу отбора в 15000 рублей. Для этого выставляем переключатель в позицию «Меньше», а в поле справа вписываем значение «15000».
Кроме того, существует ещё переключатель условий. У него два положения «И» и «ИЛИ». По умолчанию он установлен в первом положении. Это означает, что в выборке останутся только строчки, которые удовлетворяют обоим ограничениям.
Если он будет выставлен в положение «ИЛИ», то тогда останутся значения, которые подходят под любое из двух условий. В нашем случае нужно выставить переключатель в положение «И», то есть, оставить данную настройку по умолчанию.
После того, как все значения введены, щелкаем по кнопке «OK».
- Теперь в таблице остались только строчки, в которых сумма выручки не меньше 10000 рублей, но не превышает 15000 рублей.
- Аналогично можно настраивать фильтры и в других столбцах. При этом имеется возможность сохранять также фильтрацию и по предыдущим условиям, которые были заданы в колонках. Итак, посмотрим, как производится отбор с помощью фильтра для ячеек в формате даты. Кликаем по значку фильтрации в соответствующем столбце. Последовательно кликаем по пунктам списка «Фильтр по дате» и «Настраиваемый фильтр».
Источник: https://lumpics.ru/how-to-make-a-sample-in-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:
Как в Excel выбрать первое минимальное значение кроме нуля:
Как легко заметить, эти формулы отличаются между собой только функциями МИН и МАКС и их аргументами.
Скачать пример выборки из таблицы в Excel.
Теперь Вас ни что не ограничивает. Один раз разобравшись с принципами действия формул в массиве Вы сможете легко модифицировать их под множество условий и быстро решать много вычислительных задач.
Источник: https://exceltable.com/formuly/vyborka-iz-tablicy-po-usloviyu
Поиск и подстановка по нескольким условиям
89123 01.05.2015 Скачать пример
Постановка задачи
Если вы продвинутый пользователь 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 и т.д.) Многим непривычны формулы массива в принципе (тогда вам сюда).
Ссылки по теме
Источник: https://www.planetaexcel.ru/techniques/2/224/
Запрос на выборку данных (формулы) в MS EXCEL
Суть запроса на выборку – выбрать из исходной таблицы строки, удовлетворяющие определенным критериям (подобно применению стандартного Фильтра). Произведем отбор значений из исходной таблицы с помощью формул массива. В отличие от применения Фильтра (CTRL+SHIFT+L или ) отобранные строки будут помещены в отдельную таблицу.
В этой статье рассмотрим наиболее часто встречающиеся запросы, например: отбор строк таблицы, у которых значение из числового столбца попадает в заданный диапазон (интервал); отбор строк, у которых дата принаждежит определенному периоду; задачи с 2-мя текстовыми критериями и другие. Начнем с простых запросов.
1. Один числовой критерий (Выбрать те Товары, у которых цена выше минимальной)
Пусть имеется Исходная таблица с перечнем Товаров и Ценами (см. файл примера, лист Один критерий — число).
Необходимо отобразить в отдельной таблице только те записи (строки) из Исходной таблицы, у которых цена выше 25.
Решить эту и последующие задачи можно легко с помощью стандартного фильтра. Для этого выделите заголовки Исходной таблицы и нажмите CTRL+SHIFT+L. Через выпадающий список у заголовка Цены выберите Числовые фильтры…, затем задайте необходимые условия фильтрации и нажмите ОК.
Будут отображены записи удовлетворяющие условиям отбора.
Другим подходом является использование формул массива. В отличие от фильтра отобранные строки будут помещены в отдельную таблицу — своеобразный Отчет, который, например, можно отформатировать в стиль отличный от Исходной таблицы или производить другие ее модификации.
Критерий (минимальную цену) разместим в ячейке Е6, таблицу для отфильтрованных данных — в диапазоне D10:E19.
Теперь выделим диапазон D11:D19 (столбец Товар) и в Строке формул введем формулу массива:
=ИНДЕКС(A11:A19;НАИМЕНЬШИЙ(ЕСЛИ($E$6=$B$13:$B$21 гарантирует, что будут отобраны даты не позже заданной (включая). Условие $B$13:$B$21>0 необходимо, если в диапазоне дат имеются пустые ячейки. Знак * (умножение) используется для задания Условия И (все 3 критерия должны выполняться для строки одновременно).
Примечание. Случай, когда список несортирован, рассмотрен в статье Поиск ДАТЫ (ЧИСЛА) ближайшей к заданной, с условием в MS EXCEL. Несортированный список.
7. Один Текстовый критерий (Выбрать Товары определенного вида)
Пусть имеется Исходная таблица с перечнем Товаров и Ценами (см. файл примера, лист Один критерий — Текст).
Задача решается аналогично Задачам 1 и 3. Более подробное решение см. в статье Поиск ТЕКСТовых значений в MS EXCEL с выводом их в отдельный список. Часть1. Обычный поиск.
8. Два Текстовых критерия (Выбрать Товары определенного вида, поставленные в заданный месяц)
Пусть имеется Исходная таблица с перечнем Товаров и Ценами (см. файл примера, лист 2 критерия — текст (И)).
- Для отбора строк используется формула массива:
- =ИНДЕКС($A$11:$A$19;НАИМЕНЬШИЙ(ЕСЛИ(($F$6=$A$11:$A$19)*($F$7=$B$11:$B$19);СТРОКА($A$11:$A$19)-СТРОКА($A$10);30);СТРОКА(ДВССЫЛ(«A1:A»&ЧСТРОК($A$11:$A$19)))))
- Выражение ($F$6=$A$11:$A$19)*($F$7=$B$11:$B$19) задает оба условия (Товар и Месяц).
Выражение СТРОКА(ДВССЫЛ(«A1:A»&ЧСТРОК($A$11:$A$19))) формирует массив последовательных чисел {1:2:3:4:5:6:7:8:9}, т.е. номера строк в таблице.
9. Два Текстовых критерия (Выбрать Товары определенных видов)
Пусть имеется Исходная таблица с перечнем Товаров и Ценами (см. файл примера, лист 2 критерия — текст (ИЛИ)).
- В отличие от Задачи 7 отберем строки с товарами 2-х видов (Условие ИЛИ).
- Для отбора строк используется формула массива:
- =ИНДЕКС(A$11:A$19;НАИБОЛЬШИЙ((($E$6=$A$11:$A$19)+($E$7=$A$11:$A$19))*(СТРОКА($A$11:$A$19)-СТРОКА($A$10)); СЧЁТЕСЛИ($A$11:$A$19;$E$6)+СЧЁТЕСЛИ($A$11:$A$19;$E$7)-ЧСТРОК($A$11:A11)+1))
Условие ($E$6=$A$11:$A$19)+($E$7=$A$11:$A$19) гарантирует, что будут отобраны товары только заданных видов из желтых ячеек (Товар2 и Товар3). Знак + (сложение) используется для задания Условие ИЛИ (должен быть выполнен хотя бы 1 критерий).
Вышеуказанное выражение вернет массив {0:0:0:0:1:1:1:0:0}. Умножив его на выражение СТРОКА($A$11:$A$19)-СТРОКА($A$10), т.е. на массив последовательных чисел {1:2:3:4:5:6:7:8:9}, получим массив позиций (номеров строк таблицы), удовлетворяющих критериям. В нашем случае это будет массив {0:0:0:0:5:6:7:0:0}.
С помощью функции НАИБОЛЬШИЙ() выведем 3 значения из позиции 5 (строка 15 листа), 6 (16) и 7 (17), т.е. значения Товар2, Товар2 и Товар3.
Для этого используем выражение СЧЁТЕСЛИ($A$11:$A$19;$E$6)+СЧЁТЕСЛИ($A$11:$A$19;$E$7)-ЧСТРОК($A$11:A11)+1, которое последовательно (начиная со строки 11) будет возвращать числа 3; 2; 1; 0; -1; -2; … Формула НАИБОЛЬШИЙ(…;3) вернет число 5, НАИБОЛЬШИЙ(…
;2) вернет число 6, НАИБОЛЬШИЙ(…;1) вернет число 7, а НАИБОЛЬШИЙ(…;0) и далее вернет ошибку, которую мы скроем условным форматированием.
И наконец, с помощью функции ИНДЕКС() последовательно выведем наши значения из соответствующих позиций: =ИНДЕКС(A$11:A$19;5) вернет Товар2, =ИНДЕКС(A$11:A$19;6) вернет Товар2, =ИНДЕКС(A$11:A$19;7) вернет Товар3.
10. Отбор значений с учетом повторов
В разделе Отбор на основании повторяемости собраны статьи о запросах с группировкой данных. Из повторяющихся данных сначала отбираются уникальные значения, а соответствующие им значения в других столбцах — группируются (складываются, усредняются и пр.).
- Наиболее популярные статьи из этого раздела:
- Отбор уникальных значений (убираем повторы из списка) в MS EXCEL
- Отбор уникальных значений с суммированием по соседнему столбцу в MS EXCEL
- Отбор повторяющихся значений в MS EXCEL
- Отбор уникальных значений из двух диапазонов в MS EXCEL
- Отбор уникальных СТРОК с помощью Расширенного фильтра в MS EXCEL
- В качестве примера приведем решения следующей задачи: Выбрать Товары, цена которых лежит в определенном диапазоне и повторяется заданное количество раз или более.
- В качестве исходной возьмем таблицу партий товаров.
Предположим, что нас интересует сколько и каких партий товаров поставлялось по цене от 1000р. до 2000р. (критерий 1). Причем, партий с одинаковой ценой должно быть минимум 3 (критерий 2).
- Решением является формула массива:
- =НАИМЕНЬШИЙ(СТРОКА($A$14:$A$27)*($C$14:$C$27>=$B$7)*($C$14:$C$27=$B$10);F14+($G$8-$G$9))
- Эта формула возвращает номера строк, которые удовлетворяют обоим критериям.
- Формула =СУММПРОИЗВ(($C$14:$C$27>=$B$7)*($C$14:$C$27=$B$10)) подсчитывает количество строк, которые удовлетворяют критериям.
В файле примера на листе «10.Критерий — колич-во повторов» настроено Условное форматирование, которое позволяет визуально определить строки удовлетворяющие критериям, а также скрыть ячейки, в которых формула массива возвращает ошибку #ЧИСЛО!
11. Используем значение критерия (Любой) или (Все)
В фильтре Сводных таблиц MS EXCEL используется значение (Все), чтобы вывести все значения столбца. Другими словами, в выпадающем списке значений критерия содержится особое значение, которое отменяет сам критерий (см. статью Отчеты в MS EXCEL, Отчет №3).
В файле примера на листе «11. Критерий Любой или (Все)» реализован данный вариант критерия.
Формула в этом случае должна содержать функцию ЕСЛИ(). Если выбрано значение (Все), то используется формула для вывода значений без учета данного критерия. Если выбрано любое другое значение, то критерий работает обычным образом.
- =ЕСЛИ($C$8=»(Все)»;НАИМЕНЬШИЙ((СТРОКА($B$13:$B$26)-СТРОКА($B$12))*($D$13:$D$26>=$D$8);F13+($G$6-$G$7));
- НАИМЕНЬШИЙ((СТРОКА($B$13:$B$26)-СТРОКА($B$12))*($D$13:$D$26>=$D$8)*($C$13:$C$26=$C$8);F13+($G$6-$G$7)))
- Остальная часть формулы аналогична рассмотренным выше.
Источник: https://excel2.ru/articles/zapros-na-vyborku-dannyh-formuly-v-ms-excel
Excel выборка данных из таблицы
Смотрите также новый формат. Чтобы выпадающего списка. НамЗадача №2 – выбрать строка таблицы будет из таблицы (например, своеобразный отчет, который. условным форматированием. Установим.
в позицию положение результатов, которые удовлетворяют со строки 11) этого События: ЕСЛИ($D$15:$D$21;СТРОКА(A$15:A$21);»»): После ввода формулы вместо которая возвращает несколько
Суть запроса на выборку формат присваивался для нужны все Фамилии из исходной таблицы на 5 меньше текстовых), из которых можно форматировать вАктивируется окно настройки сортировки. первым ограничением нижнююАналогичным образом в столбец«Равно»«ИЛИ» заданным условиям, с будет возвращать числа
1. Один числовой критерий (Выбрать те Товары, у которых цена выше минимальной)
- Функция НАИМЕНЬШИЙ() сортирует клавиши ENTER (ВВОД) значений, то можно – выбрать из целой строки, а клиентов из столбца
товары, которые поступили чем соответственная строка функция ИНДЕКС выберет стиль отличный от Обязательно устанавливаем галочку границу отбора по
с выручкой вписываем. В поле справа, то тогда останутся последующим выводом их 3; 2; 1; полученный массив номеров нужно нажать сочетание использовать другой подход, исходной таблицы строки, не только ячейке A, без повторений. в продажу 20.09.2015. листа.
одно результирующие значение. исходной таблицы. В
напротив параметра выручке в 15000 формулу следующего содержания: от него вписываем значения, которые подходят на листе отдельным 0; -1; -2; строк: первыми идут клавиш CTRL+SHIFT+ENTER. Это который рассмотрен в удовлетворяющие определенным критериям в столбце A,
Перед тем как выбрать То есть критерийПосле того как будут Аргумент «диапазон» означает этот отчет можно«Мои данные содержат заголовки» рублей, а вторым=ИНДЕКС(C2:C29;НАИМЕНЬШИЙ(ЕСЛИ(15000
слово под любое из списком или в … Формула НАИБОЛЬШИЙ(…;3) вернет номера строк Событий,
- сочетание клавиш используется разделах ниже: 5.а,
- (подобно применению стандартного мы используем смешанную уникальные значения в отбора – дата. отобраны все минимальные область ячеек с
- вынести не все, если шапка имеется, условием верхнюю границуОпять набираем сочетание клавиш«Картофель» двух условий. В
исходном диапазоне. число 5, НАИБОЛЬШИЙ(…;2) вернет
которые удовлетворяют критерию; для ввода формул 7, 10 и Фильтра). Произведем отбор значений ссылку в формуле Excel, подготовим данные Для удобства искомую значения и сопоставлены
числовыми значениями, из столбцы, а только а галочки нет. в 20000 рублей.Ctrl+Shift+Enter. Переключатель нижнего блока нашем случае нужно
Наиболее простым способом произвести число 6, НАИБОЛЬШИЙ(…;1) вернет- Функция ИНДЕКС() выводит массива. 11. В этих из исходной таблицы
=$A4. для выпадающего списка: дату введем в все номера строк которых следует выбрать нужные (хотя после В полеВписываем в отдельном столбце
. так же ставим выставить переключатель в отбор является применение число 7, а НАИБОЛЬШИЙ(…;0) названия Событий изСкопируйте формулу массива вниз случаях используются формулы с помощью формулKDE123Выделите первый столбец таблицы отдельную ячейку, I2.
2. Два числовых критерия (Выбрать те Товары, у которых цена попадает в диапазон)
таблицы функция МИН первое наименьшее число. применения фильтра ненужные«Сортировать по» граничные условия для
Во всех трех случаях в позицию положение расширенного автофильтра. Рассмотрим, и далее вернет
указанный строк. на нужное количество массива, возвращающие одно массива. В отличие: Помогите, пожалуйста! A1:A19.
Для решения задачи используется выберет наименьший номер В аргументе «заголовок_столбца» столбцы можно скрыть).указываем наименование того выборки. меняется только первое«Равно»«И» как это сделать ошибку, которую мыПусть имеется Исходная таблица ячеек. Формула вернет
значение. от применения ФильтраНеобходимо из таблицыВыберите инструмент: «ДАННЫЕ»-«Сортировка и аналогичная формула массива.
- строки. Эта же для второй функцииОсновной недостаток – сложность
- столбца, в котором
Как и в предыдущем значение координат, а. В поле напротив, то есть, оставить на конкретном примере.
- скроем условным форматированием. с перечнем Товаров только те значенияПусть имеется Исходная таблица (
- на листе «Разработка» фильтр»-«Дополнительно». Только вместо критерия
- строка будет содержать
- СТРОКА, следует указать реализации трехуровневого Связанного содержатся скопированные значения способе, поочередно выделяем в остальном формулы него делаем запись данную настройку поВыделяем область на листе,
И наконец, с помощью и Датами поставки Товаров, которые были с перечнем ТоваровCTRL+SHIFT+L выбрать строки дляВ появившемся окне «Расширенный }. первое наименьшее число, ссылку на ячейку
списка. Но, единожды случайных чисел. В пустые столбцы новой полностью идентичны. – умолчанию. После того, среди данных которой функции ИНДЕКС() последовательно
(см. файл примера, поставлены в диапазоне и Ценами (см.или Данные/ Сортировка которых состояние «Вып» фильтр» включите «скопироватьПодобные формулы вводятся и которое встречается в
с заголовком столбца, его создав и поле таблицы и вписываем
3. Один критерий Дата (Выбрать те Товары, у которых Дата поставки совпадает заданной)
- Как видим, таблица заполнена«Мясо» как все значения нужно произвести выборку. выведем наши значения лист 2 критерия
- указанных дат. В файл примера, лист и фильтр/ Фильтр)
- и дата разработки
- результат в другое
4. Два критерия Дата (Выбрать те Товары, у которых Дата поставки попадает в диапазон)
- в другие столбцы столбце B6:B18. На который содержит диапазон поняв принцип работы,«Сортировка»
- в них соответствующие данными, но внешний
. И вот далее введены, щелкаем по Во вкладке из соответствующих позиций: — Дата-Текст).
остальных ячейках будут Диапазон Чисел). отобранные строки будут
находится в пределах место», а в
(принцип см. выше).
основании этого номера числовых значений. этот недостаток воставляем настройки по три формулы. В вид её не мы выполняем то, кнопке
«Главная» =ИНДЕКС(A$11:A$19;5) вернет Товар2, =ИНДЕКС(A$11:A$19;6) вернет Товар2, =ИНДЕКС(A$11:A$19;7) вернет Товар3.
В отличие от Задачи содержаться ошибки #ЧИСЛО!Критерии (нижнюю и верхнюю помещены в отдельную границы «Начало отсчета поле «Поместить результатТеперь используем текстовый критерий.
строки функции ИНДЕКСЕстественно эту формулу следует достаточной мере компенсируется. умолчанию. В поле
- первый столбец вносим совсем привлекателен, к чего ранее не
- «OK»щелкаем по кнопкеВ разделе Отбор на 5 будем отбирать Ошибки в файле примера
- границы цены) разместим
- таблицу. — Конец отсчета» в диапазон:» укажите
- Вместо даты в выберет соответствующее значение выполнять в массиве.Алгоритм создания запроса на«Порядок» следующее выражение:
- тому же, значения
- делали: устанавливаем переключатель
.«Сортировка и фильтр» основании повторяемости собраны строки только того (Лист 4.Диапазон Дат) скрыты в диапазонеВ этой статье рассмотрим
(Столбец L). Выбранные $F$1. ячейку I2 введем из таблицы A6:A18. Поэтому для подтверждения
- выборку следующий:можно выбрать параметр=ИНДЕКС(A2:A29;НАИМЕНЬШИЙ(ЕСЛИ(($D$2=C2:C29);СТРОКА(C2:C29);»»);СТРОКА(C2:C29)-СТРОКА($C$1))-СТРОКА($C$1)) даты заполнены в совместимости условий вТеперь в таблице остались
- . Она размещается в статьи о запросах Товара, который указан с помощью Условного
5. Один критерий Дата (Выбрать те Товары, у которых Дата поставки не раньше/ не позже заданной)
- Е5:Е6 наиболее часто встречающиеся данные разместить наОтметьте галочкой пункт «Только текст «Товар 1». В итоге формула ее ввода следует
- ШАГ 1 какВ последующие колонки вписываем ней некорректно. Нужно
- позицию
только строчки, в блоке настроек с группировкой данных. в критерии. Список форматирования..
запросы, например: отбор новом листе. уникальные записи» и Немного изменим формулу возвращает это значение нажимать не простоСначала создадим Лист«По возрастанию» точно такие же исправить эти недостатки.«ИЛИ»
5а. Один критерий Дата (Выбрать События, которые Закончились/ не начались/ происходят на заданную дату)
которых сумма выручки«Редактирование» Из повторяющихся данных
дат должен бытьАналогичную формулу нужно ввестиТ.е. если Цена Товара строк таблицы, уХотелось бы все нажмите ОК. массива: {}. в ячейку B3
- клавишу Enter, аСписки, так и формулы, только изменив Некорректность даты связана. Теперь строчка, содержащая не меньше 10000
- . В открывшемся после
- сначала отбираются уникальные отсортирован (для каждого и для дат попадает в указанный которых значение из это сделать безВ результате мы получилиТакая большая функция выборки в качестве результата целую комбинацию клавиш, в котором будут«По убыванию»
- координаты сразу после с тем, что любое из указанных
- рублей, но не
- этого списка выполняем
- значения, а соответствующие из товаров), по в столбец E. интервал, то такая
числового столбца попадает макросов. список данных с в Excel. вычисления.
CTRL+SHIFT+Enter. Если все содержаться перечень дирекций. Для случайной выборки
6. Два критерия: Дата и Текст (Выбрать Товары определенного вида, у которых Дата поставки не позже заданной)
- наименования оператора формат ячеек соответствующего условий, будет выводиться превышает 15000 рублей.
щелчок по кнопке им значения в
- товару сортировка неВ ячейке запись появится в в заданный диапазонАлексей К уникальными значениями (фамилииПоняв принцип действия формулы, сделано правильно в и названия отделов
- это значения неИНДЕКС столбца общий, а на экран. Щелкаем
- Аналогично можно настраивать фильтры«Фильтр»
- других столбцах -
требуется.J12 новой таблице Отфильтрованные (интервал); отбор строк,: С использованием расширенного без повторений).Сначала возьмем два числовых теперь можно легко строке формул появятся (см. файл примера). имеет. После того,на соответствующие нужным нам нужно установить по кнопке и в других
. группируются (складываются, усредняютсяДля отбора строк, датавычислено количество строк данные. у которых дата фильтра во вложении.
7. Один Текстовый критерий (Выбрать Товары определенного вида)
критерия: ее модифицировать и фигурные скобки.Перечень дирекций (столбец как настройки произведены, нам столбцам, по
формат даты. Выделяем«OK» столбцах. При этомЕсть возможность поступить и и пр.). которых не позже исходной таблицы, удовлетворяющихВ отличие от предыдущей принаждежит определенному периоду;
8. Два Текстовых критерия (Выбрать Товары определенного вида, поставленные в заданный месяц)
- KDE123Теперь нам необходимо немногоЗадача – отобрать товары, настраивать под другиеОбратите внимание ниже наА
- жмем на кнопку аналогии с предыдущим
- весь столбец, включая.
- имеется возможность сохранять по-другому. Для этогоНаиболее популярные статьи из
- (включая саму дату), критериям: задачи создадим два задачи с 2-мя
9. Два Текстовых критерия (Выбрать Товары определенных видов)
: Здорово! Спасибо! модифицировать нашу исходную которые стоят меньше условия. Например, формулу рисунок, где в) будет извлекаться формулой
- «OK» способом. ячейки с ошибками,Как видим, в новой
- также фильтрацию и после выделения области
- этого раздела: используется формула массива:
=СЧЁТЕСЛИМН(B12:B20;»>=»&$E$6;B12:B20;» Динамических диапазона: Товары текстовыми критериями иПоясни как работает. таблицу. Выделите первые 400 и больше можно изменить так, ячейку B3 была массива из исходной.
Каждый раз после ввода и кликаем по выборке существуют ограничения по предыдущим условиям, на листе перемещаемсяОтбор уникальных значений (убираем=ИНДЕКС(A13:A21;Строки исходной таблицы, которые и Цены (без
другие. Начнем с Как обновить результаты 2 строки и 200 рублей.
Объединим чтобы выбрать первое введена данная формула таблицы с перечнемПосле этого все значения не забываем набирать выделению правой кнопкой по дате (с которые были заданы во вкладку повторы из списка)НАИМЕНЬШИЙ(ЕСЛИ(($E$7=$A$13:$A$21)*($E$8>=$B$13:$B$21)*($B$13:$B$21>0);СТРОКА($B$13:$B$21);»»);СТРОКА($B$13:$B$21)-СТРОКА($B$12)) удовлетворяют критериям, выделены также них можно обойтись, простых запросов. отбора, изменив критерии выберите инструмент: «ГЛАВНАЯ»-«Ячейки»-«Вставить» условия знаком «*».
максимальное значение в в массиве: сотрудников: таблицы выстраиваются в сочетание клавиш
10. Отбор значений с учетом повторов
Источник: https://my-excel.ru/tablicy/excel-vyborka-dannyh-iz-tablicy.html
Как упростить выборку данных из нескольких однотипных отчетов в Excel
На руках несколько отчетов об оплатах поставок. Каждый представляет собой отдельный файл с таблицей, содержащей информацию о поквартальной динамике расчетов с конкретным поставщиком в разные периоды.
Допустим, нужно уточнить, сколько заплатили определенному контрагенту в одном из кварталов прошедшего года.
Чтобы упростить поиск и выборку таких значений, создадим еще один файл в Excel, в который скопируем все исходные однотипные таблицы из одиночных файлов.
В новом файле будет три вида листов. Первый предназначен для оглавления. Второй – рабочий, именно здесь будут задаваться параметры поиска и выводиться искомое значение. Для примера, результат выборки сумм оплат за IV квартал одному из трех контрагентов – компании «Гурман» приведен на рисунке 1.
Что касается третьей группы листов, здесь размещается вся исходная информация в однотипных таблицах (одинаковая структура, порядок размещения данных, единые единицы измерения). В нашем случае – те самые отчеты об оплатах поставщикам (по одному листу-таблице для каждого контрагента).
Количество таких листов должно соответствовать количеству однотипных таблиц, участвующих в выборке.
Рисунок 1. Рабочий лист Скачать
Создаем лист «Оглавление книги». Здесь нужно будет перечислить имена листов с исходными данными. Имена вносятся вручную начиная с ячейки А3.
- Например, для трех контрагентов это может выглядеть как на рисунке 2.
- Рисунок 2. Оглавление
Далее каждой исходной таблице необходимо присвоить имя, соответствующее названию листа. Для этого ее нужно выделить, нажать правую кнопку мыши, выбрать из появившегося контекстного меню пункт «Имя диапазона», ввести название и нажать «ОК». Например, это может выглядеть как на рисунке 3. Лист исходных данных.
- Рисунок 3. Лист исходных данных
- Кстати, имя таблице можно назначить, воспользовавшись вкладкой меню «Формулы» – в группе «Определенные имена» выбрать «Диспетчер имен» (аналогично комбинации клавиш Ctrl + F3), далее – «Создать», ввести название и нажать «ОК».
По той же схеме назначается имя «Поставщик» диапазону на листе «Оглавление книги» с перечислением названий исходных листов. Например, на рисунке 4 это диапазон «А3:А5», рассчитанный на трех контрагентов.
Рисунок 4. Название пунктов оглавления
Остается на рабочем листе создать блок для ввода параметров поиска. Допустим, их будет два: поставщик и квартал. Нет смысла вводить имя поставщика вручную, когда потребуется найти по нему информацию. Ведь даже незаметная глазу опечатка приведет к ошибкам выборки.
Пользователю будет удобнее, если он сможет указать наименование нужного контрагента в заданном списке. Для создания такого списка выбираем в меню вкладку «Данные», группу «Работа с данными», далее – «Проверка данных», тип данных «Список», в поле «Источник» вводим ранее заданное имя «Поставщик» (например, на рисунке 5.
Создание перечня поставщиков показано, как этот список создается в ячейке В1).
Рисунок 5. Создание перечня поставщиков
Для параметра «Период» также создается раскрывающийся список, но возможные значения вводятся вручную через точку с запятой в соответствующей ячейке: I;II;III;IV. Например, на рисунке 6. Создание списка периодов отражено, как такой список готовится в ячейке В3.
Рисунок 6. Создание списка периодов
Наконец задается формула, которая будет искать нужные данные по заданным параметрам. Она вводится в ячейку, в которой они должны отражаться. Например, на рисунке 7. Ввод формулы, связующей условия выборки данных это ячейка В5, а формула выглядит так: «=ВПР($B$3;ДВССЫЛ($B$1);2;ЛОЖЬ)», где:
Рисунок 7. Ввод формулы, связующей условия выборки данных
Сергей Изотов, руководитель направления финансовой и нематериальной мотивации персонала ГК «Блок»
При выборке по данным из десятков контрагентов рабочий файл Excel следует дополнить специальным макросом.
Для этого нужно открыть редактор Visual Basic Editor (комбинация клавиш «Alt+F11» или кликнуть правой кнопкой мыши на ярлык любого листа и выбрать «Исходный текст» или же в группе «Код» вкладки меню «Разработчик» щелкнуть по пункту «Visual Basic») и вставить в проект стандартный модуль. А в этот модуль добавить два кода программы (см. рисунок 8. Код программы) – ListSheet и NameAdded.
Рисунок 8. Код программы
С помощью макроса ListSheet на листе «Оглавление книги» создается список, состоящий из гиперссылок на листы с исходными данными (см. перечень контрагентов в оглавлении книги). Текст макроса выглядит так:
Поскольку оглавление по умолчанию формируется из всех листов файла (по порядку, слева направо), а нужно первые два по порядку – «Оглавление книги» и «Рабочий лист» – в нем пропустить, предпоследней строкой программы удаляются данные из диапазона ячеек A1:A2, куда попадут названия этих служебных листов («Sheets(«Оглавление книги»).Range(«A1:A2»).ClearContents»).
Макрос NameAdded присваивает таблицам с исходными значениями имена, соответствующие названиям листов, на которых они расположены. Внимание! Последние не должны содержать пробелов.
Это условие позволяет исключить распространение действия макроса на листы «Оглавление книги» и «Рабочий лист».
Кстати, при попытке присвоить имя макрос проверяет, есть ли в названии листа пробел: если да – это признается ошибкой, которая удаляется (строка 13 Err.Clear).
Сам макрос приведен ниже:
При копировании кода второй программы следует учесть несколько моментов. А именно какие строки можно менять при использовании для нужд другой компании. В частности, четвертая строка (nm.
Delete) удаляет ранее существующие имена исходных таблиц, пятая (Next nm) означает переход к следующему имени. В седьмой строке в переменную «sAlert» записываются названия листов, которые не могут быть использованы в именах, например, первые два листа: «Оглавление книги» и «Рабочий лист».
В 10 строке (Names.Add Name:=wks.Name, RefersTo:=wks.Range) указывается диапазон, которому следует присвоить имя.
В строке 17 (MsgBox) выводятся названия листов, которые не могут быть использованы в именах. В строке 18 (Names.Add Name:=»Поставщик», RefersTo:=Range («’Оглавление книги) указывается диапазон ячеек, из которых формируется список оглавления. Например, это может быть диапазон A3:A5.
Запустить оба кода программы можно нажатием сочетания клавиш «Alt+F8» или в окне «Макрос» выбрать макросы по названию и нажать кнопку «Выполнить».
В результате работы макросов получится готовый к работе файл.
Источник: https://www.fd.ru/recommend/2351-kak-uprostit-vyborku-dannyh-iz-neskolkih-odnotipnyh-otchetov-s-pomoshchyu-excel
admin / 17.10.2018
Поиск позиции в excel
Содержание
- Пример функции ПОИСКПОЗ в Excel без функции ИНДЕКС
- Пример работы ПОИСКПОЗ по двум столбцам Excel
- Описание примера как работает функция ПОИСКПОЗ:
- Поиск значения в диапазоне таблицы Excel по столбцам и строкам
- Поиск позиции элемента в списке с ПОИСКПОЗ (MATCH)
- Поиск значения в массиве Excel
- Поиск значения в столбце Excel
- Поиск значения в строке Excel
- Как получить заголовок столбца и название строки таблицы
- Поиск одинаковых значений в диапазоне Excel
- Поиск ближайшего значения в диапазоне Excel
- Автоматическая подстановка данных
- Функции ИНДЕКС и ПОИСКПОЗ в Excel – лучшая альтернатива для ВПР
- Функция ВПР с несколькими условиями критериев поиска в Excel
- Работа функции ВПР по нескольким критериям
- Функция ПОИСКПОЗ в программе Microsoft Excel
- Обработка Массивов в ms excel
- Функция ПОИСКПОЗ
- Функции ссылок и массивов Excel
- Функция ВПР
- Функция ГПР
- Функция СТРОКА
- Функция СТОЛБЕЦ
- Функция АДРЕС
- Функция ДВССЫЛ
- Функция ЧСТРОК
- Функция ЧИСЛСТОЛБ
- Функция СМЕЩ
- Функция ПОИСКПОЗ
- Функция ПОИСКПОЗ в Excel
Во многих поисковых формулах очень часто приходится использовать функцию ПОИСКПОЗ как вспомогательную в комбинациях с другими функциями такими как: ИНДЕКС, ВПР, ГПР и др. Но какую пользу может приносить данная функция работая самостоятельно. Из самого названия функции ПОИСКПОЗ понятно, что ее главная задача заключается в определении позиции исходного значения, которое содержит диапазон ячеек или таблица. Применять эту функцию очень просто для диапазонов или таблиц с одним столбцом или с одной строкой. Поэтому сразу усложним задачу и на конкретном примере проиллюстрируем как применять функцию ПОИСКПОЗ для таблицы с двумя столбцами и более.
Пример работы ПОИСКПОЗ по двум столбцам Excel
Для примера возьмем список автомобилей из автопарка средней фирмы, как показано ниже на рисунке:
В обеих столбцах названия автомобилей и отделов повторяются, но нет парных дубликатов. Например, в списке 2 автомобиля марки Ford, но оба они из разных отделов. Если мы захотим узнать номер позиции этого автомобиля, то в результате функция ПОИСПОЗ вернет нам позицию в диапазоне где встречается первое значение – 3. То есть Ford из отдела продаж:
Что же делать если нас интересует Ford из маркетингового отдела? Кроме того, мы хотим использовать только функцию ПОИСПОЗ, не прибегая к формулам с комбинациями других функций ИНДЕКС и т.п. Выход из этой ситуации находится в определении настроек аргументов и выполнения функции в массиве. Для этого:
- В ячейку B16 введите значение Ford, а в ячейку C16 название интересующего нас отдела – Маркетинговый.
- В ячейку C17 введите функцию со следующими аргументами:
- После ввода для подтверждения функции нажмите комбинацию горячих клавиш CTRL+SHIFT+Enter, так как она должна выполнятся в массиве. Если все сделано правильно в строке формул появятся фигурные скобки.
Как видно функция самостоятельно справилась с решением поставленной задачи.
Описание примера как работает функция ПОИСКПОЗ:
Чтобы функция ПОИСКПОЗ работала с таблицей с двумя столбцами как с одним мы использовали в ее аргументах оператор &. Учитывая этот оператор первый аргументом для функции теперь является значение FordМаркетинговый. По этой причине первый Ford из отдела продаж не учитывается, ведь теперь для функции два форда – это разные значения (FordПродажи и FordМаркетинговый). Просматриваемый диапазон теперь распространяется на 2 столбца, так же благодаря оператору &, который мы применяем во втором аргументе для склейки значений из двух смежных диапазонов. Таким образом, значения берутся одновременно из двух столбцов Автомобиль и Отдел.
Читайте также: Функции ИНДЕКС и ПОИСКПОЗ в Excel и примеры их использования
Поиск значения в диапазоне таблицы Excel по столбцам и строкам
Допустим ваш отчет содержит таблицу с большим количеством данных на множество столбцов. Проводить визуальный анализ таких таблиц крайне сложно. А одним из заданий по работе с отчетом является – анализ данных относительно заголовков строк и столбцов касающихся определенного месяца. На первый взгляд это весьма простое задание, но его нельзя решить, используя одну стандартную функцию.
Поиск позиции элемента в списке с ПОИСКПОЗ (MATCH)
Да, конечно можно воспользоваться инструментом: «ГЛАВНАЯ»-«Редактирование»-«Найти» CTRL+F, чтобы вызвать окно поиска значений на листе Excel. Или же создать для таблицы правило условного форматирования. Но тогда нельзя будет выполнить дальнейших вычислений с полученными результатами. Поэтому необходимо создать и правильно применить соответствующую формулу.
Поиск значения в массиве Excel
Схема решения задания выглядит примерно таким образом:
- в ячейку B1 мы будем вводить интересующие нас данные;
- в ячейке B2 будет отображается заголовок столбца, который содержит значение ячейки B1
- в ячейке B3 будет отображается название строки, которая содержит значение ячейки B1.
Фактически необходимо выполнить поиск координат в Excel. Для чего это нужно? Достаточно часто нам нужно получить координаты таблицы по значению. Немного напоминает обратный анализ матрицы. Конкретный пример в двух словах выглядит примерно так. Поставленная цель в цифрах является исходным значением, нужно определить кто и когда наиболее приближен к этой цели. Для примера используем простую матрицу данных с отчетом по количеству проданных товаров за три квартала, как показано ниже на рисунке. Важно, чтобы все числовые показатели совпадали. Если нет желания вручную создавать и заполнять таблицу Excel с чистого листа, то в конце статьи можно скачать уже с готовым примером.
Последовательно рассмотрим варианты решения разной сложности, а в конце статьи – финальный результат.
Поиск значения в столбце Excel
Сначала научимся получать заголовки столбцов таблицы по значению. Для этого выполните следующие действия:
- В ячейку B1 введите значение взятое из таблицы 5277 и выделите ее фон синим цветом для читабельности поля ввода (далее будем вводить в ячейку B1 другие числа, чтобы экспериментировать с новыми значениями).
- В ячейку C2 вводим формулу для получения заголовка столбца таблицы который содержит это значение:
- После ввода формулы для подтверждения нажимаем комбинацию горячих клавиш CTRL+SHIFT+Enter, так как формула должна быть выполнена в массиве. Если все сделано правильно в строке формул по краям появятся фигурные скобки { }.
В ячейку C2 формула вернула букву D — соответственный заголовок столбца листа. Как видно все сходиться, значение 5277 содержится в ячейке столбца D. Рекомендуем посмотреть на формулу для получения целого адреса текущей ячейки.
Поиск значения в строке Excel
Теперь получим номер строки для этого же значения (5277). Для этого в ячейку C3 введите следующую формулу:
После ввода формулы для подтверждения снова нажимаем комбинацию клавиш CTRL+SHIFT+Enter и получаем результат:
Формула вернула номер 9 – нашла заголовок строки листа по соответствующему значению таблицы. В результате мы имеем полный адрес значения D9.
Как получить заголовок столбца и название строки таблицы
Теперь научимся получать по значению координаты не целого листа, а текущей таблицы. Одним словом, нам нужно найти по значению 5277 вместо D9 получить заголовки:
- для столбца таблицы – Март;
- для строки – Товар4.
Чтобы решить данную задачу будем использовать формулу с уже полученными значениями в ячейках C2 и C3. Для этого делаем так:
- Для заголовка столбца. В ячейку D2 введите формулу: На этот раз после ввода формулы для подтверждения жмем как по традиции просто Enter:
- Для строки вводим похожую, но все же немного другую формулу:
В результате получены внутренние координаты таблицы по значению – Март; Товар 4:
На первый взгляд все работает хорошо, но что, если таблица будет содержат 2 одинаковых значения? Тогда могут возникнуть проблемы с ошибками! Рекомендуем также посмотреть альтернативное решение для поиска столбцов и строк по значению.
Поиск одинаковых значений в диапазоне Excel
Чтобы проконтролировать наличие дубликатов среди значений таблицы создадим формулу, которая сможет информировать нас о наличии дубликатов и подсчитывать их количество. Для этого в ячейку E2 вводим формулу:
Более того для диапазона табличной части создадим правило условного форматирования:
- Выделите диапазон B6:J12 и выберите инструмент: «ГЛАВНАЯ»-«Стили»-«Условное форматирование»-«Правила выделения ячеек»-«Равно».
- В левом поле введите значение $B$1, а из правого выпадающего списка выберите опцию «Светло-красная заливка и темно-красный цвет» и нажмите ОК.
- В ячейку B1 введите значение 3478 и полюбуйтесь на результат.
Как видно при наличии дубликатов формула для заголовков берет заголовок с первого дубликата по горизонтали (с лева на право). А формула для получения названия (номера) строки берет номер с первого дубликата по вертикали (сверху вниз). Для исправления данного решения есть 2 пути:
- Получить координаты первого дубликата по горизонтали (с лева на право). Для этого только в ячейке С3 следует изменить формулу на: В результате получаем правильные координаты как для листа, так и для таблицы:
- Получить координаты первого дубликата по вертикали (сверху вниз). Для этого только в ячейке С2 следует изменить формулу на:
В данном случаи изменяем формулы либо одну либо другую, но не две сразу. Стоит напомнить о том, что в ячейке С3 должна оставаться старая формула:
Здесь правильно отображаются координаты первого дубликата по вертикали (с верха в низ) – I7 для листа и Август; Товар2 для таблицы. Оставим такой вариант для следующего завершающего примера.
Поиск ближайшего значения в диапазоне Excel
Данная таблица все еще не совершенна.
Ведь при анализе нужно точно знать все ее значения. Если введенное число в ячейку B1 формула не находит в таблице, тогда возвращается ошибка – #ЗНАЧ! Идеально было-бы чтобы формула при отсутствии в таблице исходного числа сама подбирала ближайшее значение, которое содержит таблица. Чтобы создать такую программу для анализа таблиц в ячейку F1 введите новую формулу:
После чего следует во всех остальных формулах изменить ссылку вместо B1 должно быть F1! Так же нужно изменить ссылку в условном форматировании. Выберите: «ГЛАВНАЯ»-«Стили»-«Условное форматирование»-«Управление правилами»-«Изменить правило». И здесь в параметрах укажите F1 вместо B1. Чтобы проверить работу программы, введите в ячейку B1 число которого нет в таблице, например: 8000. Это приведет к завершающему результату:
Теперь можно вводить любое исходное значение, а программа сама подберет ближайшее число, которое содержит таблица. После чего выводит заголовок столбца и название строки для текущего значения. Например, если ввести число 5000 получаем новый результат:
Скачать пример поиска значения в диапазоне Excel
Наша программа в Excel нашла наиболее близкое значение 4965 для исходного – 5000. Такая программа может пригодится для автоматического решения разных аналитических задач при бизнес-планировании, постановки целей, поиска рационального решения и т.п. А полученные строки и столбцы позволяют дальше расширять вычислительные возможности такого рода отчетов с помощью новых формул Excel.
Автоматическая подстановка данных
Задание 1. Создание выпадающего списка
1. Откройте файл Ex03_1.xlsx.
2. На листе Прайс находится таблица товаров с ценами.
3. Задайте имена диапазонам с названием товара (Товар) и таблице с прайсом (Таблица) (рисунок 1). Имена диапазонов задаются для дальнейшего их использования в формулах и облегчения работы с диапазонами. Имя диапазона можно задать через поле имени ячейки или же в контекстном меню выбрать команду Присвоить имя (разумеется в том или ином случае диапазон ячеек должен быть предварительно выделен, как показано на рисунке 1).
Рисунок 1
4.
На листе продажи в столбце Наименование товара создайте выпадающий список и заполните его данными.
Для создания выпадающего списка необходимо выделить ячейки (можно сразу несколько), в которых хотите получить выпадающий список и выбрать на вкладке Данные кнопку Проверка данных (рисунок 2).
Рисунок 2
На первой вкладке Параметры из выпадающего списка Тип данных выбрать вариант Список и ввести в строчку Источник знак равно и имя диапазона с требуемыми данными (т.е. =Товар) (рисунок 3). Нажмите ОК.
Результат создания выпадающего списка представлен на рисунке 4.
Если набор значений в источнике может изменяться, лучше вставлять или удалять данные в середине списка.
Рисунок 3
Рисунок 4
Знакомство с функциями ПОИСКПОЗ и ИНДЕКС
Функции ПОИСКПОЗ и ИНДЕКС в основном применяются для автоматической подстановки данных в таблицу из заданного диапазона.
Синтаксис функций
ПОИСКПОЗ ( искомое_значение, массив, тип_сопоставления)
Массив— это блок, состоящий из одного столбца или одной строки.
Тип_сопоставления—это число -1, 0 или 1.
Если тип_сопоставленияравен 1, то функция ПОИСКПОЗнаходит наибольшее значение, которое меньше, чем искомое_значениеили равно ему. Просматриваемый массивдолжен быть упорядочен по возрастанию.
Если тип_сопоставленияравен 0,то функция ПОИСКПОЗнаходит первое значение, которое в точности равно аргументу искомое_значение.Просматриваемый массивможет быть неупорядоченным.
Если тип_сопоставленияравен -1, то функция ПОИСКПОЗнаходит наименьшее значение, которое больше, чем искомое_значение,или равно ему. Просматриваемый_массивдолжен быть упорядочен по убыванию.
Если тип_сопоставленияопущен, то предполагается, что он равен 1.
Функция ПОИСКПОЗвозвращает позицию искомого значения в массиве, а не само значение.
Функция ИНДЕКС имеет две формы. Мы рассмотрим только одну.
ИНДЕКС( таблица; номер_строки; номер_столбца)
Эта функция выбирает из прямоугольного блока (таблицы) элемент, задаваемый номерами строки и столбца, причем эти номера отсчитываются от левого верхнего элемента блока.
Давайте рассмотрим работу этих функций на конкретных примерах.
Задание 2. Знакомство с функцией ПОИСКПОЗ
С помощью функции ПОИСКПОЗ() определите позицию товара с наименованием «Иогурт» в диапазоне Товар. Для этого:
1. в электронной книге Ex03_1.xlsx перейдите на лист Прайс и установите курсор листа в любую свободную ячейку;
2. введите в эту ячейку формулу =ПОИСКПОЗ(«Йогурт»;Товар;0), т.е. мы указываем с помощью данной функции что нам необходимо найти элемент «Йогурт» (текстовое значение в функциях всегда указывается в кавычках) в диапазоне Товар, тип сопоставления 0 – точное совпадение;
3.
нажмите Enter. В результате вы должны получить число 7 (рисунок 5).
Рисунок 5
Действительно, если посмотреть на диапазон Товар, то позиция йогурта соответствует этой цифре. При этом стоит помнить, что позиция значения в массиве, т.е. в заданном диапазоне, отсчитывается от начала диапазона. Получается, что если мы добавим в начале таблицы с данными новую строку, то значение «Йогурт» сместится на строку с номером 8, но диапазон Товар начинается со значения «Молоко», поэтому с начала диапазона позиция йогурта будет в любом случае соответствовать цифре 7 (рисунок 6).
Рисунок 6
Обратите внимание на то, что в качестве значения для функции ПОИСКПОЗ() можно указывать как само значение, так и имя ячейки, в которой находится это значение. Например, запись =ПОИСКПОЗ(A7;Товар;0) позволит получить аналогичный результат как и при использовании записи =ПОИСКПОЗ(«Йогурт»;Товар;0).
Задание 3. Знакомство с функцией ИНДЕКС
Напомним, что функция ИНДЕКС() выбирает из прямоугольного блока (таблицы) элемент, задаваемый номерами строки и столбца, причем эти номера отсчитываются от левого верхнего элемента блока.
С помощью функции ИНДЕКС() найдите в диапазоне Товар элемент расположенный на пятой позиции. Для этого:
1. в электронной книге Ex03_1.xlsx на листе Прайс установите курсор листа в любую свободную ячейку;
2. введите в эту ячейку следующую функцию =ИНДЕКС(Товар;5). Нажмите Enter. Результат представлен на рисунке 7.
Рисунок 7
Обратите внимание, что мы указали для функции ИНДЕКС только значения диапазона и номер строки. Номер столбца мы указывать не стали.
Этот параметр является не обязательным если мы ищем значение в таблице (диапазоне) состоящей из одного столбца. Если же нам надо найти значение в таблице (диапазоне) состоящем из нескольких столбцов, тогда в формуле, для более точного поиска значения, необходимо указывать номер столбца.
В новой ячейке введите формулу = ИНДЕКС(Таблица;8;2). В результате вы найдете стоимость ветчины (рисунок 8).
Рисунок 8
Автоматическая подстановка данных
При работе с выпадающим списком можно автоматизировать ввод данных в таблице. Например, имеется прайс лист, содержащий названия товаров и их цену. Можно организовать выбор названия товара из списка и автоматическую подстановку цены товара в итоговую таблицу.
Автоматическая подстановка данных из справочной таблицы основывается на комбинированном использовании функций ИНДЕКС и ПОИСКПОЗ.
Задание 4. Комбинирование функций ПОИСКПОЗ и ИНДЕКС
В электронной книге Ex03_1.xlsx на листе Продажи в колонке Цена, используя функции MS Excel, обеспечьте автоматическую подстановку стоимости товара с листа Прайс, в зависимости от выбранного из выпадающего списка значения на листе Продажи.
1. Установите курсор листа в ячейку С2 и введите в нее следующую формулу:
=ИНДЕКС(Таблица; ПОИСКПОЗ(B2; Товар; 0); 2)
2. Нажмите Enter. В результате вы получите в ячейке С2 стоимость того товара, наименование которого указано в соседней колонке (рисунок 9). При выборе из выпадающего списка другого наименования товара значение цены будет изменяться соответствующим образом.
Рисунок 9
3. С помощью маркера автозаполнения продублируйте данную формулу до конца таблицы (рисунок 10).
Рисунок 10
Расшифруем данную формулу. Эта формула начинает работать с функции ПОИСКПОЗ, которая позволяет нам найти позицию значения из ячейки B2 на листе Продажи в диапазоне Товар с листа Прайс, и типом точности 0. Например, если воспользоваться списком товаров, который представлен на рисунке 10, то функция ПОИСКПОЗ ищет позицию хлеба, название которого указано в ячейке В2 из колонки Наименование товара в диапазоне Товар на листе Прайс. Эта позиция будет равна 3. Следовательно, в памяти компьютера введенная нами формула
=ИНДЕКС(Таблица; ПОИСКПОЗ(B2; Товар; 0); 2)
примет вид
=ИНДЕКС(Таблица;3; 2)
Параметр «3» – это результат работы функции ПОИСКПОЗ.
Далее вступает в работу функция ИНДЕКС, которая будет искать в диапазоне Таблица на листе Прайс значение, находящееся на пересечении третьей строки и второго столбца. (Напоминаем, что диапазон Таблица состоит из двух столбцов). Этим значением будет стоимость товара, в данном случае хлеба = 27.
Задание 5. Оформление итоговой таблицы
На листе Продажи в колонке Количество введите произвольные значения.
Вычислите значения в колонке Итого.
Задание 6. Самостоятельное задание
Откройте файл Кадры.xls. Требуется автоматизировать изменение окладов на листе Кадры.
Например, требуется кого-то из менеджеров перевести и старшие менеджеры или консультанта перевести в грузчики. Требуется проделать эту операцию для четырех сотрудников. Вместе с должностью должен изменяться и оклад.
Создайте новый лист и назовите его Штат.
Скопируйте на лист Штат столбцы Должность и Оклад.
Удалите повторяющихся сотрудников.
Для этого:
1. Выделите столбцы должность и оклад.
2. На вкладке Данные щелкните по кнопке Удалить дубликаты.
3.
Функции ИНДЕКС и ПОИСКПОЗ в Excel – лучшая альтернатива для ВПР
Удалите галочку из столбца Оклад.
4. Щелкните по кнопке Ok.
Для того, чтобы можно было изменять должности, на листе Кадры в колонке должности создайте выпадающий список. При этом потребуется менять и должностной оклад, для этого автоматизируем этот процесс так, чтобы при смене должности Excel сам менял оклад. Для этого используем функции: ПОИСКПОЗ и ИНДЕКС.
Методические указания
1. Выделите на листе Штатдиапазон должностей. Присвойте выделенному диапазону имя должность.
2. Выделите на листе Штатдиапазон окладов. Присвойте выделенному диапазону имя оклад.
3. На листе Сотрудникивстолбце Окладвведите формулу, которая бы искала на листе Штатвдиапазоне должностьпозицию соответствующую должности сотрудника, а затем из диапазона окладлиста Штатвставляла оклад, соответствующий найденной позиции.
4. После ввода формулы убедитесь, что полученный оклад действительно соответствует окладу должности сотрудника с листа Штат.
5. Измените оклад у гл. бухгалтера на листе Штат. Проверьте произошло ли изменение соответствующего оклада на листе Сотрудники.
Дата добавления: 2017-03-12; просмотров: 135 | Нарушение авторских прав
Поиск на сайте:
Функция ВПР с несколькими условиями критериев поиска в Excel
Функция ВПР (Вертикальный ПРосмотр) ищет по таблице с данными и на основе критериев запроса поиска, возвращает соответствующее значение с определенного столбца. Очень часто необходимо в запросе поиска использовать сразу несколько условий. Но по умолчанию данная функция не может обработать более одного условия. Поэтому следует использовать весьма простую формулу, которая позволит расширить возможности функции ВПР по нескольким столбцам одновременно.
Работа функции ВПР по нескольким критериям
Для наглядности разберем формулу ВПР с примером нескольких условий. Для примера будем использовать схематический отчет по выручке торговых представителей за квартал:
В данном отчете необходимо найти показатель выручки для определенного торгового представителя в определенную дату. Учитывая условия поиска наш запрос должен содержать 2 условия:
- – Дата сдачи выручки в кассу.
- – Фамилия торгового представителя.
Для решения данной задачи будем использовать функцию ВПР по нескольким условиям и составим следующую формулу:
- В ячейке С1 введите первое значение для первого критерия поискового запроса. Например, дата: 22.03.2017.
- В ячейку C2 введите фамилию торгового представителя (например, Новиков). Это значение будет использоваться в качестве второго аргумента поискового запроса.
- В ячейке C3 мы будем получать результат поиска, для этого там следует ввести формулу:
- После ввода формулы для подтверждения нажмите комбинацию горячих клавиш CTRL+SHIFT+Enter, так как формула должна быть выполнена в массиве.
Результат поиска в таблице по двум условиям:
Найдена сумма выручки конкретного торгового представителя на конкретную дату.
Разбор принципа действия формулы для функции ВПР с несколькими условиями:
Первым аргументом функции =ВПР() является первым условием для поиска значения по таблице отчета выручки торговых представителей. Во втором аргументе находится виртуальная таблица создана в результате массивного вычисления логической функцией =ЕСЛИ(). Каждая фамилия в диапазоне ячеек B6:B12 сравнивается со значением в ячейке C2. Таким образом в памяти создается условный массив данных с элементами значений ИСТИНА и ЛОЖЬ.
Потом благодаря формуле, в памяти программы каждый истинный элемент заменяется на 3-х элементный набор данных:
- элемент – Дата.
- элемент – Фамилия.
- элемент – Выручка.
А каждый ложный элемент в памяти заменяется на 3-х элементный набор пустых текстовых значений («»).
В результате создается в памяти программы новая таблица, с которой уже будет работать функция ВПР. Она игнорирует все пустые наборы данных элементов.
Функция ПОИСКПОЗ в программе Microsoft Excel
А непустые элементы сопоставляются со значением ячейки C1, использованного в качестве первого критерия поискового запроса (Дата). Одним словом, таблица в памяти проверена функцией ВПР с одним условием поиска. При положительном результате сопоставления функция возвращает значение элемента из третьего столбца (выручка) условной таблицы. Это происходит потому, что в третьем аргументе указывается номер столбца 3 из которого берутся значения. Стоит отметить что для просмотра в аргументах функции указывается целая таблица (во втором аргументе), но сам поиск всегда идет по первому столбцу в указанной таблицы.
Скачать пример функции ВПР с несколькими условиями в Excel
А из какого столбца брать возвращаемое значение указывается уже в третьем аргументе.
Число 0 в последнем аргументе функции указывает на то, то совпадение должно быть абсолютно точным.
Обработка Массивов в ms excel
⇐ Предыдущая45678910111213Следующая ⇒
Цель работы: приобрести навыки по работе с формулами массивов; изучить особенности ввода формул массива.
Методические указания
Массив — это смежный прямоугольный диапазон формул, который MS Excel обрабатывает как единое целое.
Результатом расчетов может быть как массив, так и одно число. Использование формул массива дает возможность получать компактные решения достаточно сложных задач, а в некоторых случаях без них вообще нельзя обойтись. Замена повторяющихся формул формулами массива позволяет сэкономить память, так как MS Excel хранит в памяти массив формул как единую формулу.
Пример 1. Необходимо вычислить стоимость каждого вида товара (рис. 5.1).
Рис. 5.1. Исходные данные к примеру 1
Решение. Чтобы произвести вычисления с использованием формул массива необходимо:
1. Выделить диапазон , который будет заключать в себе формулу массива.
2. Ввести формулу . Данная запись предполагает перемножение соответствующих элементов массивов. Следует отметить, что вместо указания диапазонов ячеек допустимо использование их собственных имен (например:
).
3. Завершить ввод формулы одновременным нажатием SHIFT–CTRL–ENTER. При этом автоматически появятся фигурные скобки, обрамляющие формулу. Формула массива будет записана во всех ячейках выделенного диапазона.
После того, как создан массив, содержащий формулу, нельзя вставлять ячейки в диапазон массива, удалять часть диапазона или редактировать отдельную ячейку внутри диапазона. Массив можно изменять только как единое целое. Так, например, чтобы изменить формулу массива, выделите диапазон массива, отредактируйте формулу и завершите изменения нажатием SHIFT–CTRL–ENTER.
Для коррекции формулы массива в сторону уменьшения или увеличения размеров блока можно также предложить следующий алгоритм.
1. Выделить диапазон с формулой массива и добавить в начало символ апострофа «’». Формула превратится в текст.
2. Ввести этот текст во все ячейки выделенного диапазона (CTRL–ENTER).
3. Выделить новый диапазон для формулы массива, откорректировать необходимые адреса, удалить символ апострофа и завершить изменения нажатием SHIFT–CTRL–ENTER.
Предположим, требуется получить общий итог, не вычисляя стоимость по каждому товару. Для этого в ячейке можно записать формулу массива
. Еще раз отметим, что фигурные скобки писать не следует, так как они вставляются автоматически как признак работы с массивом (явное задание фигурных скобок приведет к тому, что формула будет восприниматься как текст).
Если вычислению подлежит не общая сумма расходов, а только затраты на определенном этапе закупок. Для этого в ячейку запишем номер этапа. Тогда необходимая расчетная формула в ячейке
примет вид:
.
В MS Excel существует ряд функций, возвращающих результат в виде массива значений. Естественно, что формулы, содержащие такие функции (например, и др.), следует вводить как формулы массивов и перед их созданием выделять диапазон ячеек нужного размера.
В MS Excel допустимо использование массивов констант. Так, например, запись обозначает вектор-строку;
— вектор столбец,
— матрицу.
Функция ПОИСКПОЗ
В данном случае ввод фигурных скобок обязателен.
Пример 2. Вычислить сумму двух матриц констант можно командой . Наружные фигурные скобки при этом должны создаваться автоматически при создании формулы массива размерностью 2´2.
Пример 3. Предприятие производит продукцию двух видов и использует сырье двух типов. Нормы затрат сырья на единицу продукции каждого вида заданы матрицей , у которой по строкам указано количество сырья, расходуемого на производство единицы продукции вида 1 и 2.
Стоимость единицы сырья каждого типа задана матрицей . Каковы общие затраты предприятия на производство 100 единиц продукции первого вида и 150 единиц второго вида?
Решение. Для того, чтобы определить стоимость сырья для производства единицы продукции каждого вида, умножим матрицу строку стоимости единицы сырья B на матрицу норм затрат сырья (рис. 5.2):
Рис. 5.2. Образец нахождения стоимости сырья для производства
единицы продукции каждого вида
Объемы производства продукции зададим матрицей-столбцом , тогда суммарные затраты на производство продукции равны произведению матрицы строки С на матрицу-столбец Q (рис. 5.3):
Рис. 5.3. Образец подсчета общих затрат предприятия
Пример 4. Решить систему линейных уравнений , где
,
.
Решение. Решением этой системы является вектор. Для нахождения вектора
, введем элементы матрицы
в диапазон ячеек
, а элементы вектора
в диапазон ячеек
.
Затем необходимо выбрать диапазон , куда поместим элементы вектора решения. В этот диапазон введем формулу =МУМНОЖ(МОБР(МУМНОЖ(A2:B3;A2:B3));D2:D3) и завершим ввод формулы нажатием комбинации клавиш SHIFT–CTRL–ENTER. В результате проделанных действий в диапазоне ячеек появится решение системы уравнений (рис. 5.4).
Рис. 5.4. Образец решения примера 4
Пример 5.
Вычислить квадратичную форму , при этом
,
.
Решение. Для нахождения значения этой квадратичной формы введем элементы матрицы в диапазон ячеек
, а элементы вектора
в диапазон ячеек
. Затем необходимо выбрать ячейку
, куда поместим значение квадратичной формы. В эту ячейку введем формулу =МУМНОЖ(МОБР(МУМНОЖ(A2:B3;A2:B3));D2:D3) и завершим ввод формулы нажатием комбинации клавиш SHIFT–CTRL–ENTER. В результате проделанных действий в диапазоне ячеек появится решение системы уравнений (рис. 5.5).
Рис. 5.5. Образец решения примера 5
⇐ Предыдущая45678910111213Следующая ⇒
Дата добавления: 2016-10-06; просмотров: 211 | Нарушение авторских прав
Похожая информация:
Поиск на сайте:
Функции ссылок и массивов Excel
В данной статье рассмотрены некоторые функции по работе со ссылками и массивами:
- ВПР;
- ГПР;
- СТРОКА;
- СТОЛБЕЦ;
- АДРЕС;
- ДВССЫЛ;
- ЧСТРОК;
- ЧИСЛСТОЛБ;
- СМЕЩ;
- ПОИСКПОЗ.
Функция ВПР
Вертикальное первое равенство. Ищет совпадение по ключу в первом столбце определенного диапазона и возвращает значение из указанного столбца этого диапазона в совпавшей с ключом строке.
Синтаксис: =ВПР(ключ; диапазон; номер_столбца; [интервальный_просмотр]), где
- ключ – обязательный аргумент. Искомое значение, для которого необходимо вернуть значение.
- диапазон – обязательный аргумент. Таблица, в которой необходимо найти значение по ключу. Первый столбец таблицы (диапазона) должен содержать значение совпадающее с ключом, иначе будет возвращена ошибка #Н/Д.
- номер_столбца – обязательный аргумент. Порядковый номер столбца в указанном диапазоне из которого необходимо возвратить значение в случае совпадения ключа.
- интервальный_просмотр – необязательный аргумент. Логическое значение указывающее тип просмотра:
- ЛОЖЬ – функция ищет точное совпадение по первому столбцу таблицы. Если возможно несколько совпадений, то возвращено будет самое первое. Если совпадение не найдено, то функция возвращает ошибку #Н/Д.
- ИСТИНА – функция ищет приблизительное совпадение. Является значением по умолчанию. Приблизительное совпадение означает, если не было найдено ни одного совпадения, то функция вернет значение предыдущего ключа. При этом предыдущим будет считаться тот ключ, который идет перед искомым согласно сортировке от меньшего к большему либо от А до Я. Поэтому, перед применением функции с данным интервальным просмотром, предварительно отсортируйте первый столбец таблицы по возрастанию, так как, если это не сделать, функция может вернуть неправильный результат. Когда найдено несколько совпадений, возвращается последнее из них.
Важно не путать, что номер столбца указывается не по индексу на листе, а по порядку в указанном диапазоне.
Пример использования:
На изображении приведено 3 таблицы. Первая и вторая таблицы располагают исходными данными. Третья таблица собрана из первых двух.
В первой таблице приведены категории товара и расположение каждой категории.
Во второй категории имеется список всех товаров с указанием цен.
Третья таблица содержать часть товаров для которых необходимо определить цену и расположение.
Для цены необходимо использовать функцию ВПР с точным совпадением (интервальный просмотр ЛОЖЬ), так как данный параметр определен для всех товаров и не предусматривает использование цены другого товара, если вдруг она по случайности еще не определена.
Для определения расположения товара используется ВПР с приблизительным совпадением (интервальный просмотр ИСТИНА), так как распределение товара осуществляется по категориям. Из-за того, что наименование товара состоит из названия категории плюс дополнительный текст, по условиям сортировки от А до Я наименования товаров будут идти сразу после наименования категории, поэтому когда в таблице не обнаруживается совпадений с ключом подтягивается первое значение сверху.
В принципе, данный подход устраивал бы, если для товаров, для которых отсутствует категория, не подтягивалось расположение. Обратите внимание на товар «Лук Подмосковье». Для него определено расположение «Стелаж №2», хотя в первой таблице нет категории «Лук». Это происходит все по тем же причинам, когда функцией не обнаруживается равенств, то она определяет для значения значение меньшего самого близкого по сортировке ключа, а для «Лук Подмосковье» это категория «Картофель».
Он подобного эффекта можно избавиться путем определения категории из наименования товара используя текстовые функции ЛЕВСИМВ(C11;ПОИСК(» «;C11)-1), которые вернут все символы до первого пробела, а также изменить интервальный просмотр на точный.
Помимо всего описанного, функция ВПР позволяет применять для текстовых значений подстановочные символы – * (звездочка – любое количество любых символов) и ? (один любой символ). Например, для искомого значения «*» & «иван» & «*» могут подойти строки Иван, Иванов, диван и т.д.
Также данная функция может искать значения в массивах – =ВПР(1;{2;»Два»: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.
=ЧСТРОК({1:2:3:4:5}) – функция определят, что в массиве 5 строк.
Функция ЧИСЛСТОЛБ
Возвращает число столбцов в указанном диапазоне или массиве.
Синтаксис: =ЧИСЛСТОЛБ(ссылка), где «ссылка» обязательный аргумент, являющийся ссылкой на ячейку, диапазон либо массив.
Пример использования:
=ЧИСЛСТОЛБ(A5:D5) – результат функции 4.
=ЧИСЛСТОЛБ({1;2;3;4;5}) – функция определят, что в массиве 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 Вам помогли, то поддержите, пожалуйста, проект, чтобы мы могли развивать его дальше.
У Вас недостаточно прав для комментирования.
FILED UNDER : IT
Свежие записи
- Страница удалена картинка
- Лучший банк для бизнеса
- Операционная система для нокиа
- Что такое диакритические знаки
- Модератор в вк
- Как делать игры
- Где хранится история скайпа
- Фстэк модель угроз
- Переименовать компьютер в домене
- Преподавание в вузе
- Топ моб сайтов
- Матрица поворота в трехмерном пространстве
- Crm система
- Арктический лед – полярные льды
- Mikrotik sxt lite 2
- Что такое стек
- Хостинг на домашнем компьютере
- Видео фон для сайта
- Интернет-продажи в России: статистика, аналитика, конверсия, прогноз
- Как работает биткоин