Индекс строки ячейки в excel

Функция ИНДЕКС возвращает значение или ссылку на значение из таблицы или диапазона.

Браузер не поддерживает видео. Установите Microsoft Silverlight, Adobe Flash Player или Internet Explorer 9.

Функцию ИНДЕКС можно использовать двумя способами:

  • Если вы хотите возвращать значение указанной ячейки или массива ячеек, см. раздел Форма массива.

  • Если требуется возвращать ссылку на указанные ячейки, см. раздел Ссылочная форма.

Форма массива

Описание

Возвращает значение элемента в таблице или массиве, выбранное по индексам номеров строк и столбцов.

Если первый аргумент функции ИНДЕКС является константной массива, используйте форму массива.

Синтаксис

ИНДЕКС(массив; номер_строки; [номер_столбца])

Форма массива функции INDEX имеет следующие аргументы:

  • массив.    Обязательный аргумент. Диапазон ячеек или константа массива.

    • Если массив содержит только одну строку или столбец, соответствующий аргумент номер_строки или номер_столбца является необязательным.

    • Если массив содержит более одной строки и более одного столбца и используется только номер_строки или номер_столбца, ИНДЕКС возвращает массив всей строки или столбца в массиве.

  • Номер_строки    Обязательный, если column_num отсутствует. Выбирает строку в массиве, из которой требуется возвратить значение. Если номер_строки опущен, требуется номер_столбца.

  • Номер_столбца    — необязательный аргумент. Выбирает столбец в массиве, из которого требуется возвратить значение. Если номер_столбца опущен, требуется номер_строки.

Замечания

  • Если используются аргументы номер_строки и номер_столбца, функция ИНДЕКС возвращает значение в ячейке на пересечении номеров_строки и номера_столбца.

  • row_num и column_num должны указывать на ячейку в массиве; в противном случае ИНДЕКС возвращает #ССЫЛКА! ошибку «#ЗНАЧ!».

  • Если задать для row_num или column_num значение 0 (ноль), ИНДЕКС возвращает массив значений для всего столбца или строки соответственно. Чтобы использовать значения, возвращаемые в виде массива, введите функцию ИНДЕКС как формулу массива.

    Примечание: Если у вас есть текущая версия Microsoft 365, вы можете ввести формулу в верхнюю левую ячейку выходного диапазона, а затем нажать клавишу ВВОД, чтобы подтвердить формулу как формулу динамического массива. В противном случае формулу необходимо ввести как устаревшую формулу массива, сначала выбрав выходной диапазон, введите формулу в верхнюю левую ячейку выходного диапазона, а затем нажмите CTRL+SHIFT+ENTER для подтверждения. Excel автоматически вставляет фигурные скобки в начале и конце формулы. Дополнительные сведения о формулах массива см. в статье Использование формул массива: рекомендации и примеры.

Примеры

Пример 1

В этих примерах функция ИНДЕКС используется для поиска значения ячейки, находящейся на пересечении заданных строки и столбца.

Скопируйте образец данных из следующей таблицы и вставьте их в ячейку A1 нового листа Excel. Чтобы отобразить результаты формул, выделите их и нажмите клавишу F2, а затем — ВВОД.

Данные

Данные

Яблоки

Лимоны

Бананы

Груши

Формула

Описание

Результат

=ИНДЕКС(A2:B3;2;2)

Значение ячейки на пересечении второй строки и второго столбца в диапазоне A2:B3.

Груши

=ИНДЕКС(A2:B3;2;1)

Значение ячейки на пересечении второй строки и первого столбца в диапазоне A2:B3.

Бананы

Пример 2

В этом примере функция ИНДЕКС используется в формуле массива для поиска значений двух заданных ячеек в массиве с диапазоном 2 x 2.  

Примечание: Если у вас есть текущая версия Microsoft 365, вы можете ввести формулу в верхнюю левую ячейку выходного диапазона, а затем нажать клавишу ВВОД, чтобы подтвердить формулу как формулу динамического массива. В противном случае формулу необходимо ввести как устаревшую формулу массива, сначала выбрав две пустые ячейки, введите формулу в верхнюю левую ячейку выходного диапазона, а затем нажмите CTRL+SHIFT+ENTER для подтверждения. Excel автоматически вставляет фигурные скобки в начале и конце формулы. Дополнительные сведения о формулах массива см. в статье Использование формул массива: рекомендации и примеры.

Формула

Описание

Результат

=ИНДЕКС({1;2:3;4};0;2)

Значение ячейки на пересечении первой строки и второго столбца в массиве. Массив содержит значения 1 и 2 в первой строке и значения 3 и 4 во второй строке.

2

Значение ячейки на пересечении второй строки и второго столбца в массиве, указанном выше.

4

К началу страницы


Справочная форма

Описание

Возвращает ссылку на ячейку, расположенную на пересечении указанной строки и указанного столбца. Если ссылка состоит из несмежных выборок, вы можете выбрать выборку для поиска.

Синтаксис

ИНДЕКС(ссылка; номер_строки; [номер_столбца]; [номер_области])

Справочная форма функции ИНДЕКС имеет следующие аргументы:

  • ссылка    — обязательный аргумент. Ссылка на один или несколько диапазонов ячеек.

    • Если вы вводите несмежный диапазон для ссылки, заключите ссылку в круглые скобки.

    • Если каждая область в ссылке содержит только одну строку или столбец, аргумент номер_строки или номер_столбца соответственно является необязательным. Например, для ссылки на единственную строку нужно использовать формулу ИНДЕКС(ссылка,,номер_столбца).

  • Номер_строки    Обязательный аргумент. Номер строки в диапазоне, заданном аргументом «ссылка», из которого требуется возвратить ссылку.

  • Номер_столбца    — необязательный аргумент. Номер столбца в диапазоне, заданном аргументом «ссылка», из которого требуется возвратить ссылку.

  • area_num    Необязательный. Выбирает диапазон в ссылке, из которого возвращается пересечение row_num и column_num. Первая выбранная или введенная область имеет номер 1, вторая — 2 и так далее. Если номер_области опущен, ИНДЕКС использует область 1.  Перечисленные здесь области должны располагаться на одном листе.  Если вы укажете области, которые не находятся на одном листе друг с другом, это вызовет ошибку #ЗНАЧ! ошибку «#ВЫЧИС!».  Если вам нужно использовать диапазоны, расположенные на разных листах друг от друга, рекомендуется использовать форму массива функции ИНДЕКС, а для вычисления диапазона, из которого состоит массив, использовать другую функцию.  Например, вы можете использовать функцию ВЫБОР, чтобы вычислить, какой диапазон будет использоваться.

Например, если ссылка описывает ячейки (A1:B4,D1:E4,G1:H4), номер_области 1 – это диапазон A1:B4, номер_области 2 – это диапазон D1:E4, а номер_области 3 – диапазон G1:H4.

Замечания

  • После того, как ссылка и area_num выбрали конкретный диапазон, row_num и column_num выбирают конкретную ячейку: row_num 1 — это первая строка в диапазоне, column_num 1 — это первый столбец и так далее. Ссылка, возвращаемая INDEX, представляет собой пересечение row_num и column_num.

  • Если вы установите номер_строки или номер_столбца равным 0 (ноль), ИНДЕКС возвращает ссылку для всего столбца или строки соответственно.

  • row_num, column_num и area_num должны указывать на ячейку в пределах ссылки; в противном случае ИНДЕКС возвращает #ССЫЛКА! ошибку «#ЗНАЧ!». Если номер_строки и номер_столбца опущены, ИНДЕКС возвращает область в ссылке, указанную номером_области.

  • Результатом вычисления функции ИНДЕКС является ссылка, которая интерпретируется в качестве таковой другими функциями. В зависимости от формулы значение, возвращаемое функцией ИНДЕКС, может использоваться как ссылка или как значение. Например, формула ЯЧЕЙКА(«ширина»;ИНДЕКС(A1:B2;1;2)) эквивалентна формуле ЯЧЕЙКА(«ширина»;B1). Функция ЯЧЕЙКА использует значение, возвращаемое функцией ИНДЕКС, как ссылку. С другой стороны, такая формула, как 2*ИНДЕКС(A1:B2;1;2), преобразует значение, возвращаемое функцией ИНДЕКС, в число в ячейке B1.

Примеры

Скопируйте образец данных из следующей таблицы и вставьте их в ячейку A1 нового листа Excel. Чтобы отобразить результаты формул, выделите их и нажмите клавишу F2, а затем — клавишу Enter.

Фрукты

Цена

Количество

Яблоки

0,69 ₽

40

Бананы

0,34 ₽

38

Лимоны

0,55 ₽

15

Апельсины

0,25 ₽

25

Груши

0,59 ₽

40

Миндаль

2,80 ₽

10

Кешью

3,55 ₽

16

Арахис

1,25 ₽

20

Грецкие орехи

1,75 ₽

12

Формула

Описание

Результат

=ИНДЕКС(A2:C6;2;3)

Пересечение второй строки и третьего столбца в диапазоне A2:C6, т. е. содержимое ячейки C3.

38

=ИНДЕКС((A1:C6;A8:C11);2;2;2)

Пересечение второй строки и второго столбца во второй области (A8:C11), т. е. содержимое ячейки B9.

1,25

=СУММ(ИНДЕКС(A1:C11;0;3;1))

Сумма третьего столбца в первой области диапазона (A1:C11) является суммой диапазона C1:C11.

216

=СУММ(B2:ИНДЕКС(A2:C6;5;2))

Сумма значений из диапазона, начинающегося с ячейки B2 и заканчивающегося пересечением пятой строки и второго столбца диапазона A2:A6, т. е. сумма значений из диапазона B2:B6.

2,42

К началу страницы

См. также

Функция ВПР

ПОИСКПОЗ

Функция ДВССЫЛ

Использование формул массива: рекомендации и примеры

Функции ссылки и поиска (справка)

Функция СТРОКА

​Смотрите также​ данные. Хоть и​ Лист2, массив​​ логические значения не​​); а аргумент​

Описание

​ПОИСКПОЗ(1;(A2=’Lookup table’!$A$2:$A$13);0)*(B2=’Lookup table’!$B$2:$B$13)​ в 2015 году.​

Синтаксис

​(СРЗНАЧ). Формула вычисляет​

​ и чем больше​B​

  • ​(ИНДЕКС), должно соответствовать​​ПОИСКПОЗ​ВПР​3,55 ₽​ возвратить ссылку.​

    • ​В этих примерах функция​ угол и Маркером​В этой статье описаны​ работает это шустро,​=МИН(СТРОКА(Лист2!1:999)*ЕСЛИ(ЕПУСТО(Лист2!1:999);9E+99;1))​

    • ​ найдет.​value_if_error​В формуле, показанной выше,​Хорошо, давайте запишем формулу.​ среднее в диапазоне​ формул массива содержит​, то нужно задать​ значениям аргументов​должен быть равен​

    • ​.​16​

Примеры

​Номер_области​ ИНДЕКС используется для​ заполнения протягиваем вниз.​ синтаксис формулы и​ но к применению​vikttur​Казанский​(значение_если_ошибка) – это​ искомое значение –​ Когда мне нужно​D2:D10​ Ваша таблица, тем​ значение​

​row_num​

​0​

​Функция​

​Арахис​

​    — необязательный аргумент. Диапазон​

​ поиска значения ячейки,​

​Получаем результат как в​

​ использование функции​

​ неудобно…​

support.office.com

Нумерация строк в MS EXCEL

​: До двух знаков​: только для строк.​

Используем формулы

​ значение, которое нужно​​ это​​ создать сложную формулу​, затем находит ближайшее​ медленнее работает Excel.​2​​(номер_строки) и​​.​INDEX​1,25 ₽​

​ в аргументе «ссылка»,​ находящейся на пересечении​ предыдущем случае. Если​СТРОКА​Михаил С.​ ужмем? :)​ числа, даты и​ возвратить, если формула​1​ в Excel с​ к нему и​С другой стороны, формула​

​для аргумента​column_num​-1​​(ИНДЕКС) в Excel​​20​ из которого требуется​

​ заданных строки и​ в ячейке​в Microsoft Excel.​

Используем клавишу CTRL

​: А где нужно​=ПОИСКПОЗ(;-(A:A=»»);)​ логические значения не​​ выдаст ошибку.​​, а массив поиска​ вложенными функциями, то​​ возвращает значение из​​ с функциями​​col_index_num​​(номер_столбца) функции​– находит наименьшее​ возвращает значение из​Грецкие орехи​​ возвратить значение ячейки​​ столбца.​А3​Возвращает номер строки, определяемой​ размещать все эти​

​ikki​​ найдет.{/post}{/quote}М-да, действительно. Такой​Например, Вы можете вставить​ – это результат​ я сначала каждую​ столбца​ПОИСКПОЗ​(номер_столбца) функции​MATCH​ значение, большее или​​ массива по заданным​​1,75 ₽​ на пересечении строки​Скопируйте образец данных из​​введено значение 3,​​ ссылкой.​

Используем начало последовательности

​ «Public Function хотьчтонибудь(target​: вотЬ​ вот костыль, массив:​ формулу из предыдущего​ умножения. Хорошо, что​ вложенную записываю отдельно.​

  • ​C​​и​​ВПР​(ПОИСКПОЗ). Иначе результат​​ равное искомому значению.​​ номерам строки и​
  • ​12​​ и столбца, заданных​​ следующей таблицы и​
  • ​ т.е. задан шаг​СТРОКА([ссылка])​ As Range) As​

​UDF​=ПОИСКПОЗ(«?»;ЛЕВСИМВ(A:A;1);)​ примера в функцию​​ же мы должны​​Итак, начнём с двух​той же строки:​ИНДЕКС​, вот так:​ формулы будет ошибочным.​

Использование инструмента Прогрессия

​ Просматриваемый массив должен​ столбца. Функция имеет​Формула​ аргументами «номер_строки» и​

  • ​ вставьте их в​​ последовательности равный 2,​​Аргументы функции СТРОКА описаны​
  • ​ Long»? на этом​​вообще-то проверял, но,​​ikki​ЕСЛИОШИБКА​
  • ​ перемножить и почему?​ функций​=INDEX($C$2:$C$10,MATCH(AVERAGE($D$2:D$10),$D$2:D$10,1))​просто совершает поиск​

​=VLOOKUP(«lookup value»,A1:C10,2)​
​Стоп, стоп… почему мы​ быть упорядочен по​ вот такой синтаксис:​Описание​ «номер_столбца». Первая введенная​ ячейку A1 нового​ то мы получим​ ниже.​ же листе? они​ если чё -​: другое дело :)​вот таким образом:​

excel2.ru

ИНДЕКС (функция ИНДЕКС)

​ Давайте разберем все​ПОИСКПОЗ​=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(СРЗНАЧ($D$2:D$10);$D$2:D$10;1))​ и возвращает результат,​

​=ВПР(«lookup value»;A1:C10;2)​ не можем просто​

  • ​ убыванию, то есть​INDEX(array,row_num,[column_num])​Результат​ или выделенная область​ листа Excel. Чтобы​

  • ​ последовательность нечетных чисел.​Ссылка​ не зациклятся при​ прошу сильно не​

Форма массива

Описание

​работает также =ПОИСКПОЗ(0;ЕСЛИ(ЕПУСТО(A:A);1;0);0)​=IFERROR(INDEX($A$1:$E$11,MATCH($G$2,$B$1:$B$11,0),MATCH($G$3,$A$1:$E$1,0)),​ по порядку:​, которые будут возвращать​

​Результат: Moscow​ выполняя аналогичную работу​Если позднее Вы вставите​ использовать функцию​

Синтаксис

​ от большего к​

​ИНДЕКС(массив;номер_строки;[номер_столбца])​=ИНДЕКС(A2:C6;2;3)​

  • ​ имеет номер 1, вторая —​​ отобразить результаты формул,​Воспользуемся стандартным средством EXCEL​    Необязательный. Ячейка или диапазон​

    • ​ этом?​ бить.​ (тоже массив)​»Совпадений не найдено.​Берем первое значение в​ номера строки и​

    • ​Используя функцию​ заметно быстрее.​ новый столбец между​VLOOKUP​ меньшему.​Каждый аргумент имеет очень​Пересечение второй строки и​ 2 и т. д.​ выделите их и​ для создания прогрессий,​

  • ​ ячеек, для которых​​excelgeorge​Public Function хотьчтонибудь(target​интересно… что быстрее?..​ Попробуйте еще раз!»)​ столбце​ столбца для функции​СРЗНАЧ​

  • ​Теперь, когда Вы понимаете​​ столбцами​(ВПР)? Есть ли​На первый взгляд, польза​ простое объяснение:​ третьего столбца в​ Если аргумент «номер_области»​ нажмите клавишу F2,​

Замечания

  • ​ в то числе​ требуется вернуть номер​: здравствуйте, подскажите, пожалуйста,​ As Range) As​но… автору темы​=ЕСЛИОШИБКА(ИНДЕКС($A$1:$E$11;ПОИСКПОЗ($G$2;$B$1:$B$11;0);ПОИСКПОЗ($G$3;$A$1:$E$1;0));​A​

  • ​ИНДЕКС​в комбинации с​ причины, из-за которых​A​ смысл тратить время,​ от функции​array​ диапазоне A2:C6, т. е.​ опущен, в функции​ а затем — клавишу​ и арифметических.​ строки.​ а как поменять​ Long​ надо было не​»Совпадений не найдено.​(Customer) на листе​:​

    ​ИНДЕКС​​ стоит изучать функции​и​ пытаясь разобраться в​

  • ​ПОИСКПОЗ​(массив) – это​ содержимое ячейки C3.​ ИНДЕКС используется область 1. ​ ВВОД. При необходимости​вводим в ячейку​Если ссылка опущена, то​

Примеры

Пример 1

​ номер ячейки в​Set r =​ это :(​ Попробуйте еще раз!»)​Main table​ПОИСКПОЗ для столбца​

​и​ПОИСКПОЗ​B​ лабиринтах​вызывает сомнение. Кому​ диапазон ячеек, из​38​ Все указанные здесь​ измените ширину столбцов,​А2​ предполагается, что это​ формуле, если при​ target.Worksheet.UsedRange​

​Казанский​

​И теперь, если кто-нибудь​

​и сравниваем его​

​– мы ищем​

​ПОИСКПОЗ​

​и​

​, то значение аргумента​

​ПОИСКПОЗ​

​ нужно знать положение​

​ которого необходимо извлечь​

​=ИНДЕКС((A1:C6;A8:C11);2;2;2)​ области должны находиться​ чтобы видеть все​значение 1;​

​ ссылка на ячейку,​

​ ее протягивании автоматически​

​хотьчтонибудь = 0​: Эту формулу можно​ введет ошибочное значение,​ со всеми именами​

​ в столбце​

Пример 2

​, в качестве третьего​ИНДЕКС​ придется изменить с​и​ элемента в диапазоне?​ значение.​Пересечение второй строки и​

​ на одном листе. ​ данные.​выделяем диапазон​ в которой находится​ берется след. номер​For Each c​ упростить:​ формула выдаст вот​ покупателей в таблице​B​ аргумента функции​, давайте перейдём к​

​2​

​ИНДЕКС​

​ Мы хотим знать​

​row_num​​ второго столбца во​​ Если указать области,​

​Данные​A2:А6​ сама функция СТРОКА.​ стоки, а нужно,​ In r.Rows​=ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A);)​ такой результат:​ на листе​, а точнее в​

​ПОИСКПОЗ​

​ самому интересному и​на​?​ значение этого элемента!​

​(номер_строки) – это​

​ второй области (A8:C11),​​ находящиеся на разных​Данные​, в котором будут​Если значение аргумента «ссылка»​ чтобы брался следующий,​If Not c.Find(What:=»*»,​Но есть нюанс:​Если Вы предпочитаете в​Lookup table​ диапазоне​чаще всего нужно​ увидим, как можно​3​=VLOOKUP(«Japan»,$B$2:$D$2,3)​

​Позвольте напомнить, что относительное​

Ссылочная форма

Описание

​ номер строки в​ т. е. содержимое ячейки​ листах, произойдет ошибка​Яблоки​ содержаться номера строк;​ является диапазоном ячеек,​ то есть отнимался​ LookIn:=xlFormulas, _​ она считает непустой​

Синтаксис

​ случае ошибки оставить​

​(A2:A13).​B2:B11​

  • ​ будет указывать​​ применить теоретические знания​, иначе формула возвратит​=ВПР(«Japan»;$B$2:$D$2;3)​

    • ​ положение искомого значения​ массиве, из которой​ B9.​ #ЗНАЧ!  Если необходимо​

    • ​Лимоны​вызываем инструмент Прогрессия (Главная/​ а функция СТРОКА​ диапозон строк.​LookAt:=xlPart, MatchCase:=False) Is​ ячейку, в которой​ ячейку пустой, то​Если совпадение найдено, уравнение​, значение, которое указано​1​

  • ​ на практике.​​ результат из только​В данном случае –​ (т.е. номер строки​ нужно извлечь значение.​1,25​

  • ​ использовать диапазоны, находящиеся​​Бананы​ Редактирование/ Заполнить/ Прогрессия…),​ введена как вертикальный​Значения подтягиваются из​ Nothing Then​

  • ​ содержится пустая строка,​​ можете использовать кавычки​ возвращает​ в ячейке​или​Любой учебник по​ что вставленного столбца.​ смысла нет! Цель​ и/или столбца) –​ Если не указан,​=СУММ(ИНДЕКС(A1:C11;0;3;1))​ на разных листах,​Груши​ в появившемся окне​ массив, функция СТРОКА​ другого excel файла,​хотьчтонибудь = c.Row​ например формула =»»​ («»), как значение​1​H2​-1​ВПР​Используя​ этого примера –​ это как раз​ то обязательно требуется​Сумма третьего столбца в​ рекомендуется применить функцию​Формула​ нажимаем ОК.​ возвращает номера строк,​ но можно и​

​Exit Function​ или результат копирования-вставки​ второго аргумента функции​(ИСТИНА), а если​(USA). Функция будет​в случае, если​твердит, что эта​ПОИСКПОЗ​ исключительно демонстрационная, чтобы​

Замечания

  • ​ то, что мы​ аргумент​ первой области диапазона​ ИНДЕКС в форме​Описание​СОВЕТ:​ указанных в аргументе​ с другого листа,​End If​ как значения такой​ЕСЛИОШИБКА​ нет –​ выглядеть так:​ Вы не уверены,​ функция не может​/​

  • ​ Вы могли понять,​ должны указать для​column_num​ (A1:C11) является суммой​ массива и использовать​Результат​О специальных случаях​

  • ​ «ссылка», в виде​ не суть. Эти​Next c​ ячейки.​. Вот так:​0​=MATCH($H$2,$B$1:$B$11,0)​ что просматриваемый диапазон​ смотреть влево. Т.е.​ИНДЕКС​ как функции​ аргументов​

  • ​(номер_столбца).​ диапазона C1:C11.​ другую функцию для​=ИНДЕКС(A2:B3;2;2)​ нумерации строк можно​ вертикального массива.​ значения идут на​End Function​Предыдущие формулы такую​IFERROR(INDEX(массив,MATCH(искомое_значение,просматриваемый_массив,0),»»)​(ЛОЖЬ).​=ПОИСКПОЗ($H$2;$B$1:$B$11;0)​ содержит значение, равное​ если просматриваемый столбец​, Вы можете удалять​ПОИСКПОЗ​row_num​column_num​216​ вычисления диапазона, составляющего​

​Значение ячейки на пересечении​​ почитать в статьях​В аргументе «ссылка» нельзя​ каждой строке, а​

Примеры

​применение: =хотьчтонибудь(Лист1!A:IV)​ ячейку считают пустой.​ЕСЛИОШИБКА(ИНДЕКС(массив;ПОИСКПОЗ(искомое_значение;просматриваемый_массив;0);»»)​Далее, мы делаем то​Результатом этой формулы будет​ среднему. Если же​ не является крайним​ или добавлять столбцы​и​(номер_строки) и/или​(номер_столбца) – это​=СУММ(B2:ИНДЕКС(A2:C6;5;2))​ массив.  Например, определить​

​ второй строки и​

​ Автоматическая перенумерация строк​

​ указывать несколько областей.​

​ не через 10​

​можно и для​

​ikki​

​Надеюсь, что хотя бы​

​ же самое для​

​4​

​ Вы уверены, что​

​ левым в диапазоне​

​ к исследуемому диапазону,​

​ИНДЕКС​

​column_num​

​ номер столбца в​

​Сумма значений из диапазона,​

​ используемый диапазон можно​

​ второго столбца в​

​ при применении фильтра,​

​Скопируйте образец данных из​

​ строк каждое, как​

​ текущего листа: =хотьчтонибудь(A:IV)​

​: угум. я тоже​

​ одна формула, описанная​

​ значений столбца​

​, поскольку «USA» –​

​ такое значение есть,​

​ поиска, то нет​

​ не искажая результат,​

​работают в паре.​

​(номер_столбца) функции​

​ массиве, из которого​

​ начинающегося с ячейки​

​ с помощью функции​

​ диапазоне A2:B3.​ Автоматическая нумерация при​ следующей таблицы и​ мне было бы​

​Казанский​

​ думал, что можно​

​ в этом учебнике,​B​ это 4-ый элемент​ – ставьте​ шансов получить от​

​ так как определен​

​ Последующие примеры покажут​

​INDEX​ нужно извлечь значение.​ B2 и заканчивающегося​ ВЫБОР.​

​Груши​

​ добавлении строк, Сохранение​

​ вставьте их в​ удобнее и не​: Если Find, то​ упростить.​ показалась Вам полезной.​(Product).​ списка в столбце​0​

​ВПР​

​ непосредственно столбец, содержащий​

support.office.com

Функции ИНДЕКС и ПОИСКПОЗ в Excel – лучшая альтернатива для ВПР

​ Вам истинную мощь​(ИНДЕКС). Как Вы​​ Если не указан,​​ пересечением пятой строки​​Например, если аргумент «ссылка»​​=ИНДЕКС(A2:B3;2;1)​ нумерации при удалении​ ячейку A1 нового​ возникло бы вопросов.​​ зачем цикл :)​​но упрощенная -​ Если Вы сталкивались​Затем перемножаем полученные результаты​B​для поиска точного​желаемый результат.​​ нужное значение. Действительно,​​ связки​

​ помните, функция​ то обязательно требуется​ и второго столбца​ определяет ячейки (A1:B4,D1:E4,G1:H4),​Значение ячейки на пересечении​​ строк, Нумерация строк​​ листа Excel. Чтобы​Если честно, то​Set r =​ она работает НЕПРАВИЛЬНО.​ с другими задачами​ (1 и 0).​​(включая заголовок).​​ совпадения.​Функции​ это большое преимущество,​ИНДЕКС​

​ИНДЕКС​ аргумент​ диапазона A2:A6, т. е.​​ номер области 1​​ второй строки и​ и столбцов римскими​ отобразить результаты формул,​ оч трудно сформулировать,​ target.Worksheet.cells.Find(…​например, если в​ поиска, для которых​ Только если совпадения​ПОИСКПОЗ для строки​​Если указываете​​ПОИСКПОЗ​​ особенно когда работать​​и​может возвратить значение,​row_num​ сумма значений из​ соответствует диапазону A1:B4,​​ первого столбца в​​ цифрами и Нумерация​

ИНДЕКС и ПОИСКПОЗ в Excel

  • ​ выделите их и​ проще показать.​
  • ​if not r​ первой ячейке пусто,​
  • ​ не смогли найти​ найдены в обоих​
  • ​– мы ищем​1​
    • ​и​ приходится с большими​
    • ​ПОИСКПОЗ​ находящееся на пересечении​
    • ​(номер_строки)​ диапазона B2:B6.​
    • ​ номер области 2​
    • ​ диапазоне A2:B3.​ столбцов буквами.​

Базовая информация об ИНДЕКС и ПОИСКПОЗ

​ нажмите клавишу F2,​Пример ниже, заранее​ is nothing then​​ во второй -​​ подходящее решение среди​​ столбцах (т.е. оба​​ значение ячейки​, значения в столбце​ИНДЕКС​ объёмами данных. Вы​, которая легко справляется​

​ заданных строки и​Если указаны оба аргумента,​2,42​ — диапазону D1:E4,​Бананы​Функция ИНДЕКС возвращает значение​​ а затем — клавишу​​ спасибо​​ хотьчтонибудь = r.row​​ дата, а третья​​ информации в этом​​ критерия истинны), Вы​

ИНДЕКС – синтаксис и применение функции

​H3​​ поиска должны быть​​в Excel гораздо​ можете добавлять и​ с многими сложными​ столбца, но она​ то функция​К началу страницы​

​ а номер области​
​В этом примере функция​

​ или ссылку на​ ВВОД. При необходимости​

  • ​PooHkrd​​Только вот метод​ снова пустая, то​ уроке, смело опишите​ получите​
  • ​(2015) в строке​​ упорядочены по возрастанию,​ более гибкие, и​ удалять столбцы, не​ ситуациями, когда​ не может определить,​ИНДЕКС​Этот учебник рассказывает о​​ 3 — диапазону​​ ИНДЕКС используется в​
  • ​ значение из таблицы​​ измените ширину столбцов,​: Если я все​ Find не работает​ такая формула дает​ свою проблему в​1​1​​ а формула вернёт​​ им все-равно, где​

​ беспокоясь о том,​ВПР​​ какие именно строка​​возвращает значение из​ главных преимуществах функций​ G1:H4.​ формуле массива для​

​ или диапазона.​​ чтобы видеть все​​ правильно понял и​

​ в UDF в​
​ #Н/Д.​

​ комментариях, и мы​. Если оба критерия​​, то есть в​​ максимальное значение, меньшее​ находится столбец со​​ что нужно будет​​оказывается в тупике.​​ и столбец нас​​ ячейки, находящейся на​ИНДЕКС​​После того как с​​ поиска значений двух​

​Функцию ИНДЕКС можно использовать​ данные.​ вам требуется чтобы​ моем любимом 2000​а вот если​ все вместе постараемся​ ложны, или выполняется​​ ячейках​​ или равное среднему.​

ПОИСКПОЗ – синтаксис и применение функции

​ значением, которое нужно​​ исправлять каждую используемую​​Решая, какую формулу использовать​ интересуют.​ пересечении указанных строки​и​ помощью аргументов «ссылка»​ заданных ячеек в​

​ двумя способами:​​Формула​​ при протягивании формула​ :(​ третья — тоже​ решить её.​​ только один из​​A1:E1​Если указываете​ извлечь. Для примера,​

​ функцию​
​ для вертикального поиска,​

​Теперь, когда Вам известна​​ и столбца.​​ПОИСКПОЗ​ и «номер_области» выбран​

​ массиве с диапазоном​
​Если вы хотите возвращать​

  • ​Описание​​ не изменялась в​ikki​ дата, то результат​Урок подготовлен для Вас​ них – Вы​:​-1​
  • ​ снова вернёмся к​​ВПР​ большинство гуру Excel​ базовая информация об​
  • ​Вот простейший пример функции​​в Excel, которые​ диапазон, с помощью​​ 2 x 2.​​ значение указанной ячейки​Результат​ некотором количестве строк,​
    • ​: мда… усложнил малость.​​ равен 3.​​ командой сайта office-guru.ru​​ получите​=MATCH($H$3,$A$1:$E$1,0)​, значения в столбце​ таблице со столицами​.​ считают, что​ этих двух функциях,​
    • ​INDEX​​ делают их более​ аргументов «номер_строки» и​В этом случае нужно​​ или массива ячеек,​​=СТРОКА()​​ после чего уже​​все равно это​неупрощенная — работает​Источник: https://www.ablebits.com/office-addins-blog/2014/08/13/excel-index-match-function-vlookup/​​0​​=ПОИСКПОЗ($H$3;$A$1:$E$1;0)​​ поиска должны быть​​ государств и населением.​
    • ​3. Нет ограничения на​​ИНДЕКС​ полагаю, что уже​(ИНДЕКС):​ привлекательными по сравнению​ «номер_столбца» выбирается конкретная​ выбрать любые две​ см. раздел Форма​Строка формулы​

​ ссылалась бы на​ должно работать быстрее,​​ правильно во всех​​Перевел: Антон Андронов​.​Результатом этой формулы будет​ упорядочены по убыванию,​ На этот раз​

​ размер искомого значения.​/​ становится понятно, как​=INDEX(A1:C10,2,3)​ с​ ячейка: номер строки​ ячейки по вертикали,​ массива.​​2​​ другой диапазон, то​​ чем формулы массива,​​ случаях.​​Автор: Антон Андронов​​Теперь понимаете, почему мы​5​​ а возвращено будет​​ запишем формулу​Используя​ПОИСКПОЗ​ функции​=ИНДЕКС(A1:C10;2;3)​ВПР​ 1 соответствует первой​ например A1:A2, вставить​

Как использовать ИНДЕКС и ПОИСКПОЗ в Excel

​Если требуется возвращать ссылку​=СТРОКА(C10)​ вам нужно сначала​ тем более смотрим​вообще-то странно.​Excel-ok​​ задали​​, поскольку «2015» находится​​ минимальное значение, большее​​ПОИСКПОЗ​​ВПР​​намного лучше, чем​ПОИСКПОЗ​Формула выполняет поиск в​. Вы увидите несколько​​ строке диапазона, номер​​ в первую ячейку​ на указанные ячейки,​Строка ссылки​ прописать вручную необходимый​

​ не весь лист,​пс. у меня​​: =МИН(ЕСЛИ(ДЛСТР(СТРОКА(Лист1!1:65536))>0;СТРОКА(Лист1!1:65536)))​​1​​ в 5-ом столбце.​​ или равное среднему.​

​/​, помните об ограничении​ВПР​
​и​ диапазоне​ примеров формул, которые​

​ столбца 1 —​ формулу =ИНДЕКС({1;2:3;4};0;2) и​ см. раздел Ссылочная​10​ по размерам блок​

ИНДЕКС и ПОИСКПОЗ в Excel

​ а UsedRange.​ Excel 2003… можть,​/как формула массива/​, как искомое значение?​

​Теперь вставляем эти формулы​
​В нашем примере значения​

​ИНДЕКС​ на длину искомого​. Однако, многие пользователи​

  • ​ИНДЕКС​​A1:C10​​ помогут Вам легко​ его первому столбцу​​ нажать клавиши CTRL+SHIFT+ВВОД.​​ форма.​Используем различные подходы для​​ формул, потом протягивать​​но, кшн, можно​​ глючный какой?​​по задумке должна​ Правильно, чтобы функция​ в функцию​
  • ​ в столбце​​, которая покажет, какое​​ значения в 255​​ Excel по-прежнему прибегают​​могут работать вместе.​​и возвращает значение​​ справиться со многими​ и т. д.​ Если ввести формулу​Возвращает значение элемента таблицы​ нумерации строк.​

    ​ вниз не одну​
    ​ и без цикла.​

    ​Михаил С.​ возвращать номер первой​ПОИСКПОЗ​​ИНДЕКС​​D​​ место по населению​​ символов, иначе рискуете​ к использованию​ПОИСКПОЗ​ ячейки во​​ сложными задачами, перед​​ Ссылка, возвращаемая функцией​ как формулу массива,​ или массив, заданного​

​Пусть в ячейке​ ячейку с формулой,​

ИНДЕКС и ПОИСКПОЗ в Excel

​но тогда обязательно​: =ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A);0) (по умолчанию​ по счету строки​​возвращала позицию только,​​и вуаля:​упорядочены по возрастанию,​​ занимает столица России​​ получить ошибку​​ВПР​​определяет относительную позицию​​2-й​​ которыми функция​ ИНДЕКС, указывает на​

​ Excel автоматически вставит​ номером строки и​A2​​ а весь блок​​ надо задать в​ 1)​ в которой хоть​ когда оба критерия​​=INDEX($A$1:$E$11,MATCH($H$2,$B$1:$B$11,0),MATCH($H$3,$A$1:$E$1,0))​​ поэтому мы используем​​ (Москва).​​#VALUE!​

​, т.к. эта функция​
​ искомого значения в​

​строке и​ВПР​ пересечение строки «номер_строки»​ ее во вторую​ номером столбца.​введено значение 1​​ целиком.​​ Find SearchOrder:=xlByRows​​Казанский​​ что-нибудь есть​ выполняются.​=ИНДЕКС($A$1:$E$11;ПОИСКПОЗ($H$2;$B$1:$B$11;0);ПОИСКПОЗ($H$3;$A$1:$E$1;0))​ тип сопоставления​​Как видно на рисунке​​(#ЗНАЧ!). Итак, если​​ гораздо проще. Так​​ заданном диапазоне ячеек,​3-м​бессильна.​​ и столбца «номер_столбца».​​ ячейку.​

Почему ИНДЕКС/ПОИСКПОЗ лучше, чем ВПР?

​Если первый аргумент функции​ (номер первой строки).​Ну, в общем​ikki​​: Нет. Если бы​​(формула находится на​​Обратите внимание:​​Если заменить функции​​1​​ ниже, формула отлично​ таблица содержит длинные​ происходит, потому что​​ а​​столбце, то есть​В нескольких недавних статьях​Если указать в качестве​Формула​ ИНДЕКС является константной​ В следующую строку​ ответил, как минимум,​​: ну виртуозы!!!​​ было так =ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A))​​ листе Лист2, книга​​В этом случае​​ПОИСКПОЗ​​. Формула​ справляется с этой​ строки, единственное действующее​ очень немногие люди​

​ИНДЕКС​ из ячейки​​ мы приложили все​​ аргумента «номер_строки» или​​Описание​​ массива, используйте форму​ таблицы, в ячейку​ не хуже чем​​и, самое главное​​это было бы​​ с этими листами​​ необходимо использовать третий​​на значения, которые​​ИНДЕКС​

4 главных преимущества использования ПОИСКПОЗ/ИНДЕКС в Excel:

​ задачей:​​ решение – это​ до конца понимают​​использует это число​​C2​ усилия, чтобы разъяснить​ «номер_столбца» значение 0​Результат​ массива.​А3​ поставлена задача.​ — обработает скрытые​​ как по умолчанию​​ создана и сохранена)​​ не обязательный аргумент​​ они возвращают, формула​/​=INDEX($A$2:$A$10,MATCH(«Russia»,$B$2:$B$10,0))​ использовать​ все преимущества перехода​ (или числа) и​.​ начинающим пользователям основы​ (ноль), функция ИНДЕКС​

​=ИНДЕКС({1;2​ИНДЕКС(массив; номер_строки; [номер_столбца])​​, вводим формулу =А2+1​​З.Ы. В примере​​ строки/столбцы и будет​ =ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A);1)​почему она не​ функции​ станет легкой и​ПОИСКПО​​=ИНДЕКС($A$2:$A$10;ПОИСКПОЗ(«Russia»;$B$2:$B$10;0))​​ИНДЕКС​ с​ возвращает результат из​Очень просто, правда? Однако,​​ функции​​ возвратит ссылку на​:​Аргументы функции ИНДЕКС описаны​ и копируем ее​ не понятно вообще​

​ работать в любом​А =ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A);) эквивалентно​​ работает?​​ИНДЕКС​ понятной:​​З​​Теперь у Вас не​/​​ВПР​​ соответствующей ячейки.​​ на практике Вы​​ВПР​​ целый столбец или​​3;4};0;2)​

​ ниже.​
​ в ячейки ниже.​

​ ничего.​ Эксе, хоть в​ =ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A);0)​​Михаил С.​​. Он необходим, т.к.​​=INDEX($A$1:$E$11,4,5))​​возвращает «Moscow», поскольку​ должно возникать проблем​​ПОИСКПОЗ​​на связку​​Ещё не совсем понятно?​​ далеко не всегда​и показать примеры​ целую строку соответственно.​

​Значение ячейки на пересечении​​Массив​​Так как в формуле​​excelgeorge​​ 97-м.​ikki​: Потому, что, если​ в первом аргументе​=ИНДЕКС($A$1:$E$11;4;5))​ величина населения города​ с пониманием, как​.​ИНДЕКС​ Представьте функции​ знаете, какие строка​ более сложных формул​Аргументы «номер_строки», «номер_столбца» и​ первой строки и​    — обязательный аргумент. Диапазон​ мы сослались на​:​​The_Prist, снимаю шляпу.​​: =ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A);0) (по умолчанию​

​ ее чуть преобразовать,​ мы задаем всю​​Эта формула возвращает значение​​ Москва – ближайшее​​ работает эта формула:​Предположим, Вы используете вот​и​ИНДЕКС​ и столбец Вам​​ для продвинутых пользователей.​​ «номер_области» должны указывать​ второго столбца в​ ячеек или константа​ ячейку выше с​vikttur​​Казанский​​ 1){/post}{/quote}​​ то получим​​ таблицу и должны​

​ на пересечении​ меньшее к среднему​​Во-первых, задействуем функцию​​ такую формулу с​ПОИСКПОЗ​​и​​ нужны, и поэтому​​ Теперь мы попытаемся,​​ на ячейку внутри​ массиве. Массив содержит​​ массива.​​ помощью относительной ссылки,​

​: =ИНДЕКС($B$1:$B$100;(СТРОКА(A1)-1)/14+1)​
​: Не спеши со​

​разобрался.​=МИН(ЕСЛИ(ДЛСТР(1:65536)>0;СТРОКА(Лист1!1:65536)));​ указать функции, из​​4-ой​​ значению (12 269​MATCH​ВПР​, а тратить время​​ПОИСКПОЗ​​ требуется помощь функции​​ если не отговорить​​ аргумента «ссылка»; в​

​ значения 1 и​
​Если массив содержит только​

​ то EXCEL при​Играйтесь знаменателем.​​ шляпой ;)​мне, кшн, стыдно,​в любом случае​ какого столбца нужно​строки и​ 006).​(ПОИСКПОЗ), которая находит​, которая ищет в​ на изучение более​в таком виде:​ПОИСКПОЗ​ Вас от использования​ противном случае функция​ 2 в первой​​ одну строку или​​ копировании вниз модифицирует​​excelgeorge​​Сравни с дополненным​​ но страна должна​​ ДЛСТР(1:65536)>0=истина;​ извлечь значение. В​5-го​​Эта формула эквивалентна двумерному​​ положение «Russia» в​

​ ячейках от​​ сложной формулы никто​​=INDEX(столбец из которого извлекаем,(MATCH​.​ВПР​ ИНДЕКС возвращает значение​ строке и значения​​ один столбец, соответствующий​​ вышеуказанную формулу в​: спасибо, попробую​ вариантом:​ знать своих героев.​если проверять по​​ нашем случае это​​столбца в диапазоне​ поиску​ списке:​B5​ не хочет.​ (искомое значение,столбец в​

​Функция​, то хотя бы​​ ошибки #ССЫЛКА!. Если​​ 3 и 4​​ аргумент «номер_строки» или​​ =А3+1, затем в​PerfectVam​Public Function хотьчтонибудь(target​Excel реабилитирован.​

ИНДЕКС и ПОИСКПОЗ – примеры формул

​ столбцу А:А, то​ столбец​A1:E11​​ВПР​​=MATCH(«Russia»,$B$2:$B$10,0))​​до​​Далее я попробую изложить​ котором ищем,0))​MATCH​ показать альтернативные способы​ аргументы «номер_строки» и​

Как выполнить поиск с левой стороны, используя ПОИСКПОЗ и ИНДЕКС

​ во второй строке.​​ «номер_столбца» не является​​ =А4+1 и т.д.,​: А вот так​ As Range) As​оказалось, что это​=МИН(ЕСЛИ(ДЛСТР(A1:A65536);СТРОКА(Лист1!1:65536)))​C​, то есть значение​и позволяет найти​​=ПОИСКПОЗ(«Russia»;$B$2:$B$10;0))​​D10​

​ главные преимущества использования​​=ИНДЕКС(столбец из которого извлекаем;(ПОИСКПОЗ(искомое​​(ПОИСКПОЗ) в Excel​​ реализации вертикального поиска​​ «номер_столбца» опущены, функция​2​ обязательным.​ тем самым формируя​ можно привязаться к​ Long​ я глючный :)​не проверял​(Sum), и поэтому​ ячейки​ значение на пересечении​​Далее, задаём диапазон для​​значение, указанное в​​ПОИСКПОЗ​​ значение;столбец в котором​ ищет указанное значение​ в Excel.​ ИНДЕКС возвращает область​

​Значение ячейки на пересечении​Если массив содержит больше​ числовую последовательность 2,​ D1 и отслеживать​

​Dim avArr, lr​
​формулы =ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A);) и​

ИНДЕКС и ПОИСКПОЗ в Excel

​Serge​ мы ввели​E4​ определённой строки и​

  • ​ функции​​ ячейке​​и​ ищем;0))​ в диапазоне ячеек​

    ​Зачем нам это? –​
    ​ в аргументе "ссылка",​

  • ​ второй строки и​ одной строки и​​ 3, 4, …​​ по совпадающему с​ As Long, lc​ =ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A);0) — это​: Потому что минимальная​​3​​. Просто? Да!​
  • ​ столбца.​INDEX​

    ​A2​
    ​ИНДЕКС​

​Думаю, ещё проще будет​​ и возвращает относительную​ спросите Вы. Да,​ заданную аргументом «номер_области».​​ второго столбца в​​ одного столбца, а​​Другим вариантом является использование​​ ним началу строки:​ As Long, r​ одно и то​ длинна строки массива​

Вычисления при помощи ИНДЕКС и ПОИСКПОЗ в Excel (СРЗНАЧ, МАКС, МИН)

​.​В учебнике по​​В этом примере формула​​(ИНДЕКС), из которого​​:​​в Excel, а​ понять на примере.​ позицию этого значения​ потому что​Результатом вычисления функции ИНДЕКС​ массиве, указанном выше.​ из аргументов «номер_строки»​

​ формулы =СТРОКА()-СТРОКА($A$1). В​​=ЕСЛИ(ЛЕВСИМВ($D2;ДЛСТР($D$1))=$D$1;ИНДЕКС(знач!B:B;СУММПРОИЗВ(—(ЛЕВСИМВ($D$1:$D2;ДЛСТР($D$1))=$D$1)));»»)​​ As Range​ же.​​ СТРОКА(Лист1!1:65536)= 1​​И, наконец, т.к. нам​ВПР​​ИНДЕКС​​ нужно извлечь значение.​

​=VLOOKUP(A2,B5:D10,3,FALSE)​
​ Вы решите –​

​ Предположим, у Вас​

​ в диапазоне.​​ВПР​​ является ссылка, которая​4​​ и «номер_столбца» задан​​ ячейке​I1POKE3​​Set r =​​но, если умудриться​

​Excel-ok​
​ нужно проверить каждую​

​мы показывали пример​

​/​​ В нашем случае​​=ВПР(A2;B5:D10;3;ЛОЖЬ)​ остаться с​​ есть вот такой​​Например, если в диапазоне​– это не​ интерпретируется в качестве​Примечание:​​ только один, функция​​А1​

​: Скажите пожулуйста, как​
​ target.Parent.UsedRange​

​ не заметить последний​

О чём нужно помнить, используя функцию СРЗНАЧ вместе с ИНДЕКС и ПОИСКПОЗ

​: Формула​​ ячейку в массиве,​​ формулы с функцией​​ПОИСКПОЗ​​ это​​Формула не будет работать,​​ВПР​ список столиц государств:​​B1:B3​​ единственная функция поиска​ таковой другими функциями.​​ Это формула массива, которую​​ ИНДЕКС возвращает массив,​​должен находиться заголовок​​ узнать номер выделенной​If r.Count =​ «;» в первой​=МИН(ЕСЛИ(ДЛСТР(1:65536)>0;СТРОКА(Лист1!1:65536)))​ эта формула должна​ВПР​будет очень похожа​A2:A10​​ если значение в​​или переключиться на​Давайте найдём население одной​

  • ​содержатся значения New-York,​​ в Excel, и​​ В зависимости от​ нужно вводить с​ состоящий из целой​ столбца.​ сторки.​ 1 Then​
  • ​ формуле, т.е. набрать​​вероятно, должна считать​​ быть формулой массива.​для поиска по​ на формулы, которые​.​ ячейке​ИНДЕКС​

​ из столиц, например,​ Paris, London, тогда​​ её многочисленные ограничения​​ формулы значение, возвращаемое​ помощью клавиш CTRL+SHIFT+ВВОД.​ строки или целого​​Для чрезстрочной нумерации используйте​​Спасибо большое.​​If r <>​​ =ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A)), то она,​​ то что нужно,​​ Вы можете видеть​​ нескольким критериям. Однако,​ мы уже обсуждали​Затем соединяем обе части​A2​/​ Японии, используя следующую​

ИНДЕКС и ПОИСКПОЗ в Excel

Как при помощи ИНДЕКС и ПОИСКПОЗ выполнять поиск по известным строке и столбцу

​ следующая формула возвратит​ могут помешать Вам​​ функцией ИНДЕКС, может​​ Excel автоматически заключит​ столбца аргумента «массив».​ формулу (см. файл​Mahru​

​ «» Then хотьчтонибудь​​ есс-но будет понята​​ но после ввода​​ это по фигурным​​ существенным ограничением такого​ в этом уроке,​ и получаем формулу:​длиннее 255 символов.​ПОИСКПОЗ​ формулу:​

​ цифру​ получить желаемый результат​​ использоваться как ссылка​​ формулу в фигурные​Номер_строки​

​ примера) =ЕСЛИ(ЕЧЁТН(СТРОКА());"";A7+1)​
​: На всякие случай​

​ = r.Row​ как =ПОИСКПОЗ(ЛОЖЬ;ЕПУСТО(A:A);1) и​ ее в ячеку​

​ скобкам, в которые​ решения была необходимость​ с одним лишь​=INDEX($A$2:$A$10;MATCH(«Russia»;$B$2:$B$10;0))​ Вместо неё Вам​​.​​=INDEX($D$2:$D$10,MATCH(«Japan»,$B$2:$B$10,0))​​3​​ во многих ситуациях.​ или как значение.​ скобки {}. Если​​     — обязательный аргумент.​​Пусть, как и в​ =СТРОКА()​

​Exit Function​ будет работать "неправильно".​ было получено сообщение​ она заключена. Поэтому,​ добавлять вспомогательный столбец.​
​ отличием. Угадайте каким?​=ИНДЕКС($A$2:$A$10;ПОИСКПОЗ("Russia";$B$2:$B$10;0))​ нужно использовать аналогичную​1. Поиск справа налево.​=ИНДЕКС($D$2:$D$10;ПОИСКПОЗ("Japan";$B$2:$B$10;0))​

​, поскольку «London» –​ С другой стороны,​ Например, формула ЯЧЕЙКА(«ширина»;ИНДЕКС(A1:B2;1;2))​ вы попытаетесь ввести​​ Выбирает строку в​​ предыдущем примере, в​​I1POKE3​​Else​

​вот такие нюансы.​ суть которого в​ когда закончите вводить​ Хорошая новость: формула​Как Вы помните, синтаксис​Подсказка:​ формулу​Как известно любому​

ИНДЕКС и ПОИСКПОЗ в Excel

​Теперь давайте разберем, что​ это третий элемент​ функции​ эквивалентна формуле ЯЧЕЙКА(«ширина»;B1).​ их вручную, Excel​ массиве, из которой​ ячейку​

​: Нет. Я ни​avArr = r.Value​​Excel-ok​​ том, что ресурсы​ формулу, не забудьте​ИНДЕКС​​ функции​​Правильным решением будет​

  • ​ИНДЕКС​​ грамотному пользователю Excel,​ делает каждый элемент​​ в списке.​​ИНДЕКС​ Функция ЯЧЕЙКА использует​​ отобразит формулу как​​ требуется возвратить значение.​A2​​ сколечко не здеваюсь!!!​​For lr =​: Вероятно, что то,​

    ​ Эксель закончились... И​
    ​ нажать​

    ​/​​INDEX​​ всегда использовать абсолютные​/​ВПР​​ этой формулы:​​=MATCH(«London»,B1:B3,0)​

  • ​и​​ значение, возвращаемое функцией​ текст. Если при​​ Если аргумент «номер_строки»​​введено значение 1.​​В прошлой теме​​ 1 To UBound(avArr,​ что хочется формулами​​ это при том,​​Ctrl+Shift+Enter​

    ​ПОИСКПОЗ​
    ​(ИНДЕКС) позволяет использовать​

    ​ ссылки для​​ПОИСКПОЗ​​не может смотреть​Функция​

​=ПОИСКПОЗ(«London»;B1:B3;0)​ПОИСКПОЗ​​ ИНДЕКС, как ссылку.​​ вводе формулы не​

​ опущен, аргумент "номер_столбца"​
​ Выделим ячейку​

​ написаны 3 способа​​ 1)​​ сделать не удастся..​ что это единственная​.​может искать по​

​ три аргумента:​
​ИНДЕКС​

​:​ влево, а это​​MATCH​​Функция​​– более гибкие​​ С другой стороны,​​ нажать клавиши CTRL+SHIFT+ВВОД,​​ является обязательным.​A2​​ как выделить строку​​For lc =​

ИНДЕКС и ПОИСКПОЗ в Excel

Поиск по нескольким критериям с ИНДЕКС и ПОИСКПОЗ

​:(​​ формула в книге…​​Если всё сделано верно,​ значениям в двух​​INDEX(array,row_num,[column_num])​​и​=INDEX(D5:D10,MATCH(TRUE,INDEX(B5:B10=A2,0),0))​ значит, что искомое​(ПОИСКПОЗ) ищет значение​MATCH​ и имеют ряд​​ такая формула, как​​ она возвратит ошибку​​Номер_столбца​​. Удерживая клавишу​ через активную ячейку,​ 1 To UBound(avArr,​ikki​

​Вопрос остался: с​ Вы получите результат​ столбцах, без необходимости​ИНДЕКС(массив;номер_строки;[номер_столбца])​ПОИСКПОЗ​​=ИНДЕКС(D5:D10;ПОИСКПОЗ(ИСТИНА;ИНДЕКС(B5:B10=A2;0);0))​​ значение должно обязательно​​ «Japan» в столбце​​(ПОИСКПОЗ) имеет вот​ особенностей, которые делают​ 2*ИНДЕКС(A1:B2;1;2), преобразует значение,​ #ЗНАЧ!​     — необязательный аргумент.​CTRL​ то бишь не​​ 2)​​: ну вот )​ пом. формулы определить​

ИНДЕКС и ПОИСКПОЗ в Excel

​ как на рисунке​​ создания вспомогательного столбца!​​И я поздравляю тех​​, чтобы диапазоны поиска​​4. Более высокая скорость​

​ находиться в крайнем​
​B​

​ такой синтаксис:​
​ их более привлекательными,​

​ возвращаемое функцией ИНДЕКС,​К началу страницы​ Выбирает столбец в​, скопируем Маркером заполнения​​ зная ее номера.​​If Len(avArr(lr, lc))​​ пока писал, а​​ номер самой первой​ ниже:​Предположим, у нас есть​​ из Вас, кто​​ не сбились при​ работы.​

​ левом столбце исследуемого​
​, а конкретно –​

​MATCH(lookup_value,lookup_array,[match_type])​ по сравнению с​ в число в​​Возвращает ссылку на ячейку,​​ массиве, из которого​ (при этом над​Я применил их​ Then​ тут уже и​ по счету строки​Как Вы, вероятно, уже​

  • ​ список заказов, и​ догадался!​​ копировании формулы в​​Если Вы работаете​​ диапазона. В случае​​ в ячейках​ПОИСКПОЗ(искомое_значение;просматриваемый_массив;[тип_сопоставления])​ВПР​ ячейке B1.​​ расположенную на пересечении​​ требуется возвратить значение.​
  • ​ курсором появится маленький​ все, и понял,​​хотьчтонибудь = lr:​​ ответ готов.​ в которой находится​​ заметили (и не​​ мы хотим найти​
  • ​Начнём с того, что​ другие ячейки.​ с небольшими таблицами,​​ с​​B2:B10​
  • ​lookup_value​.​Примечание:​ указанной строки и​ Если аргумент «номер_столбца»​ плюсик), значение из​ что мне это​​ Exit For​​но я таки​ хотя бы что-то​ раз), если вводить​ сумму по двум​ запишем шаблон формулы.​​Вы можете вкладывать другие​​ то разница в​

​ПОИСКПОЗ​, и возвращает число​​(искомое_значение) – это​​Базовая информация об ИНДЕКС​  Функция ЯЧЕЙКА недоступна​​ указанного столбца. Если​​ опущен, аргумент «номер_строки»​A2​ не помогает.​

​End If​​ сам допёр. :)​ (любое значение). Но​ некорректное значение, например,​ критериям –​​ Для этого возьмём​​ функции Excel в​ быстродействии Excel будет,​/​3​ число или текст,​ и ПОИСКПОЗ​ в Excel Web​ ссылка составлена из​ является обязательным.​​в ячейки ниже.​​Как оказалось мне​Next lc​​ikki​​ чтобы формуле, конечно,​

​ которого нет в​имя покупателя​ уже знакомую нам​ИНДЕКС​ скорее всего, не​ИНДЕКС​, поскольку «Japan» в​ который Вы ищите.​Используем функции ИНДЕКС и​ App.​ несмежных выделенных диапазонов,​Если используются оба аргумента​​ Получим последовательность чисел​​ нужно узнать номер​

​If хотьчтонибудь >​: встроенными функциями -​ хватало ресурсов..​ просматриваемом массиве, формула​

ИНДЕКС и ПОИСКПОЗ в Excel

ИНДЕКС и ПОИСКПОЗ в сочетании с ЕСЛИОШИБКА в Excel

​(Customer) и​ формулу​и​ заметная, особенно в​, столбец поиска может​ списке на третьем​​ Аргумент может быть​​ ПОИСКПОЗ в Excel​​Скопируйте образец данных из​​ можно указать, какой​​ — и «номер_строки»,​​ 1, 2, 3,​​ строки, в которой​​ 0 Then Exit​ наверное, нет.​:-)​ИНДЕКС​продукт​ИНДЕКС​​ПОИСКПОЗ​​ последних версиях. Если​​ быть, как в​​ месте.​​ значением, в том​​Преимущества ИНДЕКС и ПОИСКПОЗ​

​ следующей таблицы и​​ из них требуется​​ и «номер_столбца», —​

​ 4 …​
​ находиться выделенная ячейка.​

​ For​​но, если Вам​​Михаил С.​/​(Product). Дело усложняется​/​, например, чтобы найти​​ же Вы работаете​​ левой, так и​​Функция​​ числе логическим, или​​ перед ВПР​​ вставьте их в​ использовать.​ функция ИНДЕКС возвращает​ВНИМАНИЕ!​

​ Причем, не посмотрев​Next lr​ так принципиально наличие​​: 1. Если хотите​​ПОИСКПОЗ​

​ тем, что один​
​ПОИСКПОЗ​ минимальное, максимальное или​
​ с большими таблицами,​
​ в правой части​INDEX​

​ ссылкой на ячейку.​ИНДЕКС и ПОИСКПОЗ –​ ячейку A1 нового​ИНДЕКС(ссылка; номер_строки; [номер_столбца]; [номер_области])​

ИНДЕКС и ПОИСКПОЗ в Excel

​ значение ячейки на​Если на листе​ его в экселе​End If​ формулы, то можно​ искать по всему​​сообщает об ошибке​​ покупатель может купить​

​и добавим в​
​ ближайшее к среднему​

​ которые содержат тысячи​ диапазона поиска. Пример:​(ИНДЕКС) использует​lookup_array​ примеры формул​ листа Excel. Чтобы​Аргументы функции ИНДЕКС описаны​ пересечении указанных строки​ часть строк скрыта​ на экране, а​хотьчтонибудь = хотьчтонибудь​ сделать UDF, а​ листу, то формула​#N/A​ сразу несколько разных​

​ неё ещё одну​ значение. Вот несколько​
​ строк и сотни​
​ Как находить значения,​

​3​

office-guru.ru

Формула определяющая номер строки (например) для ячейки в которой хоть что-нть есть

​(просматриваемый_массив) – диапазон​​Как находить значения, которые​
​ отобразить результаты формул,​

​ ниже.​ и столбца.​ с помощью фильтра,​ что бы я​ + r.Row -​
​ в макросе -​ должна быть на​(#Н/Д) или​ продуктов, и имена​

​ функцию​ вариантов формул, применительно​

​ формул поиска, Excel​​ которые находятся слева​для аргумента​ ячеек, в котором​
​ находятся слева​
​ выделите их и​Ссылка​
​Если указать в качестве​ то этот подход​
​ мог использовать его​
​ 1​

​ поиск или перебор​​ другом листе -​#VALUE!​ покупателей в таблице​

​ПОИСКПОЗ​​ к таблице из​
​ будет работать значительно​

​ покажет эту возможность​row_num​ происходит поиск.​Вычисления при помощи ИНДЕКС​ нажмите клавишу F2,​    — обязательный аргумент. Ссылка​ аргумента «номер_строки» или​ и остальные, приведенные​ в макросе.​End Function​ в цикле For​

​ иначе циклическая ссылка.​(#ЗНАЧ!). Если Вы​ на листе​, которая будет возвращать​ предыдущего примера:​ быстрее, при использовании​ в действии.​(номер_строки), который указывает​match_type​
​ и ПОИСКПОЗ​

​ а затем — клавишу​​ на один или​ «номер_столбца» значение 0​ ниже, работать не​webley​в случае если:​ Each.​
​2. Для поиска​ хотите заменить такое​Lookup table​ номер столбца.​1.​ПОИСКПОЗ​
​2. Безопасное добавление или​ из какой строки​(тип_сопоставления) – этот​

​Поиск по известным строке​​ ВВОД. При необходимости​

​ несколько диапазонов ячеек.​​ (ноль), функция ИНДЕКС​ будут. Чтобы разрешить​: Первый способ из​- лист пустой;​но всё равно,​ по всему листу​ сообщение на что-то​
​расположены в произвольном​=INDEX(Ваша таблица,(MATCH(значение для вертикального​MAX​и​

​ удаление столбцов.​​ нужно возвратить значение.​ аргумент сообщает функции​ и столбцу​ измените ширину столбцов,​

​Если в качестве аргумента​​ возвратит массив значений​ нумерацию строк с​ 3-х — это​- занята одна​ как Вам уже​

​ поставте комп по-мощнее;​

​ более понятное, то​​ порядке.​
​ поиска,столбец, в котором​(МАКС). Формула находит​

​ИНДЕКС​

​Формулы с функцией​ Т.е. получается простая​ПОИСКПОЗ​

​Поиск по нескольким критериям​​ чтобы видеть все​ «ссылка» используется несмежный​

​ для целого столбца​

​ использованием клавиши​ и есть номер​ ячейка;​ сказали, циклических ссылок​ 64 бит операционку​ можете вставить формулу​Вот такая формула​ искать,0)),(MATCH(значение для горизонтального​
​ максимум в столбце​вместо​

​ВПР​​ формула:​, хотите ли Вы​ИНДЕКС и ПОИСКПОЗ в​
​ данные.​ диапазон, его необходимо​
​ или целой строки​CTRL​ строки:​- Usedrange не​ создавать не нужно.​ и 8 гигов​ с​
​ИНДЕКС​ поиска,строка в которой​D​ВПР​

​перестают работать или​=INDEX($D$2:$D$10,3)​ найти точное или​
​ сочетании с ЕСЛИОШИБКА​

​Фрукты​ заключить в скобки​ соответственно. Чтобы использовать​

​, выделите любую ячейку​​ActiveCell.Row​ начинается с 1​

​то есть можно​​ памяти…​ИНДЕКС​
​/​ искать,0))​и возвращает значение​

​. В целом, такая​ возвращают ошибочные значения,​

​=ИНДЕКС($D$2:$D$10;3)​​ приблизительное совпадение:​Так как задача этого​

​Цена​
​Если каждая область в​ значения, возвращенные как​ с заголовком фильтра​
​Hugo​
​ строки.​ искать по всему​

​Вывод — в​и​ПОИСКПОЗ​=ИНДЕКС(Ваша таблица,(MATCH(значение для вертикального​
​ из столбца​ замена увеличивает скорость​ если удалить или​Формула говорит примерно следующее:​1​ учебника – показать​Количество​ ссылке содержит только​

​ массив, введите функцию​

​ и дважды нажмите​​: Что-то мне кажется,​Чтобы ф-я пересчитывалась​ листу (если очень​
​ этом случае макрос​

​ПОИСКПОЗ​​решает задачу:​ поиска,столбец, в котором​C​ работы Excel на​
​ добавить столбец в​ ищи в ячейках​

​или​​ возможности функций​Яблоки​
​ одну строку или​ ИНДЕКС как формула​CTRL+SHIFT+L​ что человеку не​ при изменении на​ надо), но с​ незаменим.​в функцию​
​{=INDEX(‘Lookup table’!$A$2:$C$13,MATCH(1,(A2=’Lookup table’!$A$2:$A$13)*​ искать,0)),(MATCH(значение для горизонтального​той же строки:​13%​
​ таблицу поиска. Для​ от​не указан​ИНДЕКС​0,69 ₽​

​ один столбец, аргумент​​ массива в горизонтальный​

​(сбросьте фильтр).​​ активную ячейку надо​ листе, надо добавить​
​ другого листа.​Казанский​ЕСЛИОШИБКА​

​(B2=’Lookup table’!$B$2:$B$13),0),3)}​ поиска,строка в которой​=INDEX($C$2:$C$10,MATCH(MAX($D$2:I$10),$D$2:D$10,0))​.​
​ функции​D2​
​– находит максимальное​и​40​

​ «номер_строки» или «номер_столбца»​

​ диапазон ячеек для​​Если начало последовательности уже​ знать, а найденную​
​Application.Volatile​

​vikttur​​: =ПОИСКПОЗ(«*»;A:A;)​
​.​
​{=ИНДЕКС(‘Lookup table’!$A$2:$C$13;ПОИСКПОЗ(1;(A2=’Lookup table’!$A$2:$A$13)*​ искать,0))​=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(МАКС($D$2:I$10);$D$2:D$10;0))​Влияние​

​ВПР​до​ значение, меньшее или​
​ПОИСКПОЗ​Бананы​
​ соответственно является необязательным.​
​ строки и в​ задано (т.е. задан​
​ кодом. Т.е. сперва​kim​
​: =ПОИСКПОЗ(;—ЕПУСТО(A1:A100);)​vikttur​
​Синтаксис функции​
​(B2=’Lookup table’!$B$2:$B$13);0);3)}​
​Обратите внимание, что для​
​Результат: Beijing​
​ВПР​

​любой вставленный или​
​D10​ равное искомому. Просматриваемый​

​для реализации вертикального​​0,34 ₽​ Например, для ссылки​

​ вертикальный — для столбца.​ первый элемент и​
​ типа​: А макрофункции чего​Казанский​

​: Вы заставляете Excel​ЕСЛИОШИБКА​Эта формула сложнее других,​ двумерного поиска нужно​2.​

​на производительность Excel​​ удалённый столбец изменит​
​и извлеки значение​ массив должен быть​ поиска в Excel,​38​ на единственную строку​ Чтобы ввести формулу​
​ шаг последовательности), то​Set rgX =​
​ никто не предложил?​: Ну вот, пришел​ создавать массив из​

​очень прост:​​ которые мы обсуждали​
​ указать всю таблицу​MIN​ особенно заметно, если​ результат формулы, поскольку​ из третьей строки,​ упорядочен по возрастанию,​

​ мы не будем​

​Лимоны​​ нужно использовать формулу​ массива, нажмите сочетание​
​ пронумеровать строки можно​ Cells.Find(What:=curRec, LookIn:=xlValues, LookAt:=xlWhole,​

​ :)​ Формулист :)​ (хорошо еще, если​
​IFERROR(value,value_if_error)​ ранее, но вооруженные​ в аргументе​(МИН). Формула находит​
​ рабочая книга содержит​ синтаксис​
​ то есть из​ то есть от​
​ задерживаться на их​0,55 ₽​ ИНДЕКС(ссылка,,номер_столбца).​
​ клавиш CTRL+SHIFT+ВВОД.​
​ следующим образом :​
​ MatchCase:=False)​
​На листе единственная​В данном случае​ Excel-2003) 65536*256 значений,​
​ЕСЛИОШИБКА(значение;значение_если_ошибка)​ знанием функций​array​
​ минимум в столбце​ сотни сложных формул​
​ВПР​ ячейки​
​ меньшего к большему.​
​ синтаксисе и применении.​
​15​Номер_строки​Примечание:​
​пусть в ячейке​
​и далее использовать​
​ заполненная ячейка -​ один минус лишний:​ вот он и​
​Где аргумент​

​ИНДЕКС​
​(массив) функции​
​D​ массива, таких как​
​требует указывать весь​D4​0​

​Приведём здесь необходимый минимум​Апельсины​    — обязательный аргумент. Номер​
​  В Excel Web​

​А2​​rgX.Row или rgX.Column​ G18, формула в​ =ПОИСКПОЗ(;-ЕПУСТО(A:A);)​
​ возмущается. И правильно​value​и​INDEX​и возвращает значение​ВПР+СУММ​ диапазон и конкретный​, так как счёт​– находит первое​ для понимания сути,​0,25 ₽​ строки в диапазоне,​ App невозможно создавать​введено значение 1,​ или даже rgX.Address​

​ ней возвращает свое​​> Вероятно, что​ делает :)​(значение) – это​ПОИСКПОЗ​(ИНДЕКС).​ из столбца​. Дело в том,​ номер столбца, из​

planetaexcel.ru

Как автоматически менять номер строки в формуле с заданным интервалом?

​ начинается со второй​​ значение, равное искомому.​ а затем разберём​25​ заданном аргументом «ссылка»,​ формулы массива.​ а в ячейке​Чтоб вообще лишний​ же местоположение по​ то, что хочется​Задайте диапазон ячеек.​
​ значение, проверяемое на​Вы одолеете ее.​А теперь давайте испытаем​C​ что проверка каждого​ которого нужно извлечь​ строки.​ Для комбинации​ подробно примеры формул,​Груши​ из которого требуется​Аргументы «номер_строки» и «номер_столбца»​
​А3​ раз без Select/Activate…​ строкам. По идее,​
​ формулами сделать не​ И такой, чтобы​

​ предмет наличия ошибки​​ Самая сложная часть​ этот шаблон на​той же строки:​ значения в массиве​ данные.​Вот такой результат получится​ИНДЕКС​ которые показывают преимущества​0,59 ₽​ возвратить ссылку.​ должны указывать на​значение 2;​I1POKE3​ если заполнять данные​ удастся.. :(​ формула в него​ (в нашем случае​
​ – это функция​ практике. Ниже Вы​=INDEX($C$2:$C$10,MATCH(MIN($D$2:I$10),$D$2:D$10,0))​ требует отдельного вызова​;)​Например, если у Вас​ в Excel:​/​

​ использования​​40​

​Номер_столбца​​ ячейку внутри заданного​
​выделяем ячейки​

​: Всем спасибо.​​ выше ее -​

​Ну почему же​​ не попадала (зацикливание).​ – результат формулы​ПОИСКПОЗ​ видите список самых​=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(МИН($D$2:I$10);$D$2:D$10;0))​
​ функции​

planetaexcel.ru

Как узнать номер строки?

​ есть таблица​​Важно! Количество строк и​ПОИСКПОЗ​ИНДЕКС​
​Миндаль​

​    — необязательный аргумент. Номер​​ массива; в противном​A2A3​

​Вариантов предостаточно.​​ она должна возвращать​ :)​
​ikki​ИНДЕКС​, думаю, её нужно​ населённых стран мира.​Результат: Lima​ВПР​
​A1:C10​ столбцов в массиве,​всегда нужно точное​и​
​2,80 ₽​ столбца в диапазоне,​ случае функция ИНДЕКС​;​Пойду пробовать, уверен,​ номер первой строки,​Вот функция для​: только для строк.​/​ объяснить первой.​

​ Предположим, наша задача​​3.​. Поэтому, чем больше​, и требуется извлечь​ который использует функция​
​ совпадение, поэтому третий​

​ПОИСКПОЗ​​10​ заданном аргументом «ссылка»,​ возвратит значение ошибки​беремся за правый нижний​ что все получится.​ в которой есть​
​ первых 999 строк​ числа, даты и​ПОИСКПОЗ​

​MATCH(1,(A2=’Lookup table’!$A$2:$A$13),0)*(B2=’Lookup table’!$B$2:$B$13)​
​ узнать население США​AVERAGE​

​ значений содержит массив​ данные из столбца​

​INDEX​​ аргумент функции​
​вместо​
​Кешью​ из которого требуется​

planetaexcel.ru

​ #ССЫЛКА!.​

Бывает у вас такое: смотришь на человека и думаешь «что за @#$%)(*?» А потом при близком знакомстве оказывается, что он знает пять языков, прыгает с парашютом, имеет семеро детей и черный пояс в шахматах, да и, вообще, добрейшей души человек и умница?

Так и в Microsoft Excel: есть несколько похожих функций, про которых фраза «внешность обманчива» работает на 100%. Одна из наиболее многогранных и полезных — функция ИНДЕКС (INDEX). Далеко не все пользователи Excel про нее знают, и еще меньше используют все её возможности. Давайте разберем варианты ее применения, ибо их аж целых пять.

Вариант 1. Извлечение данных из столбца по номеру ячейки

Самый простой случай использования функции ИНДЕКС – это ситуация, когда нам нужно извлечь данные из одномерного диапазона-столбца, если мы знаем порядковый номер ячейки. Синтаксис в этом случае будет:

=ИНДЕКС(Диапазон_столбец; Порядковый_номер_ячейки)

Простой вариант ИНДЕКС

Этот вариант известен большинству продвинутых пользователей Excel. В таком виде функция ИНДЕКС часто используется в связке с функцией ПОИСКПОЗ (MATCH), которая выдает номер искомого значения в диапазоне. Таким образом, эта пара заменяет легендарную ВПР (VLOOKUP):

ИНДЕКС в связке с ПОИСКПОЗ

… но, в отличие от ВПР, могут извлекать значения левее поискового столбца и номер столбца-результата высчитывать не нужно.

Вариант 2. Извлечение данных из двумерного диапазона

Если диапазон двумерный, т.е. состоит из нескольких строк и столбцов, то наша функция будет использоваться немного в другом формате:

=ИНДЕКС(Диапазон; Номер_строки; Номер_столбца)

ИНДЕКС 2 вариант

Т.е. функция извлекает значение из ячейки диапазона с пересечения строки и столбца с заданными номерами.

Легко сообразить, что с помощью такой вариации ИНДЕКС и двух функций ПОИСКПОЗ можно легко реализовать двумерный поиск:

Двумерный поиск с ИНДЕКС и ПОИСКПОЗ

Вариант 3. Несколько таблиц

Если таблица не одна, а их несколько, то функция ИНДЕКС может извлечь данные из нужной строки и столбца именно заданной таблицы. В этом случае используется следующий синтаксис:

=ИНДЕКС((Диапазон1;Диапазон2;Диапазон3); Номер_строки; Номер_столбца; Номер_диапазона

ИНДЕКС с неск.таблицами

Обратите особое внимание, что в этом случае первый аргумент – список диапазонов — заключается в скобки, а сами диапазоны перечисляются через точку с запятой.

Вариант 4. Ссылка на столбец / строку

Если во втором варианте использования функции ИНДЕКС номер строки или столбца задать равным нулю (или просто не указать), то функция будет выдавать уже не значение, а ссылку на диапазон-столбец или диапазон-строку соответственно:

ИНДЕКС выдающая ссылку на целую строку-столбец

Обратите внимание, что поскольку ИНДЕКС выдает в этом варианте не конкретное значение ячейки, а ссылку на диапазон, то для подсчета потребуется заключить ее в дополнительную функцию, например СУММ (SUM), СРЗНАЧ (AVERAGE) и т.п.

Вариант 5. Ссылка на ячейку

Общеизвестно, что стандартная ссылка на любой диапазон ячеек в Excel выглядит как Начало-Двоеточие-Конец, например A2:B5. Хитрость в том, что если взять функцию ИНДЕКС в первом или втором варианте и подставить ее после двоеточия, то наша функция будет выдавать уже не значение, а адрес, и на выходе мы получим полноценную ссылку на диапазон от начальной ячейки до той, которую нашла ИНДЕКС:

ИНДЕКС как часть ссылки

Нечто похожее можно реализовать функцией СМЕЩ (OFFSET), но она, в отличие от ИНДЕКС, является волатильной, т.е. пересчитывается каждый раз при изменении любой ячейки листа. ИНДЕКС же работает более тонко и запускает пересчет только при изменении своих аргументов, что ощутимо ускоряет расчет в тяжелых книгах по сравнению со СМЕЩ.

Один из весьма распространенных на практике сценариев применения ИНДЕКС в таком варианте — это сочетание с функцией СЧЁТЗ (COUNTA), чтобы получить автоматически растягивающиеся диапазоны для выпадающих списков, сводных таблиц и т.д.

Ссылки по теме

  • Трехмерный поиск данных по нескольким листам (ВПР 3D)
  • Поиск и подстановка по нескольким условиям (ВПР по нескольким столбцам)
  • Подстановка данных из одной таблицы в другую с помощью функции ВПР (VLOOKUP)

Skip to content

Функция ИНДЕКС в Excel — 6 примеров использования

В этом руководстве вы найдете ряд примеров формул, демонстрирующих наиболее эффективное использование ИНДЕКС в Excel.

Из всех функций Excel, возможности которых часто недооцениваются и используются недостаточно, ИНДЕКС определенно занимает место в первой десятке. Между тем, эта функция умна, гибка и универсальна.

Итак, что такое функция ИНДЕКС в Excel? По сути, формула ИНДЕКС (в английской версии – INDEX) возвращает ссылку на ячейку из заданного массива или диапазона. Другими словами, вы используете её, когда знаете (или можете определить) положение элемента в диапазоне и хотите затем получить значение этого элемента.

  • Синтаксис и способы использования
  • Получение N-го элемента из списка
  • Получение всех значений в строке или столбце
  • Использование ИНДЕКС с другими функциями (СУММ, СРЗНАЧ, МАКС, МИН)
  • Формула ИНДЕКС для создания динамических диапазонов и раскрывающихся списков
  • Мощный поиск с ИНДЕКС/ПОИСКПОЗ
  • Формула ИНДЕКС для получения одного диапазона из списка диапазонов

Если вы оцените реальный потенциал функции ИНДЕКС, это может кардинально изменить способы расчета, анализа и представления данных в ваших таблицах.

Функция ИНДЕКС в Excel — синтаксис и основные способы использования

В Excel есть две версии функции ИНДЕКС — форма массива и форма ссылки. Обе их можно использовать во всех версиях Microsoft Excel 365, 2019, 2016, 2013, 2010, 2007 и 2003.

Форма массива ИНДЕКС

В данном случае функция ИНДЕКС возвращает значение элемента в таблице или массиве на основе указанных вами номеров строк и столбцов.

ИНДЕКС(массив,номер_строки,[номер_столбца])

  • массив — это диапазон ячеек, именованный диапазон или таблица.
  • Номер_строки — это номер строки в массиве, из которого нужно вернуть значение. Если этот аргумент опущен, требуется следующий – номер_столбца.
  • Номер_столбца — это номер столбца, из которого нужно вернуть значение. Если он опущен, требуется номер_строки.

Например, формула =ИНДЕКС(C2:F11;4;3)  возвращает значение на пересечении четвертой строки и третьего столбца в диапазоне C2:F11, что является значением в ячейке D4.

Чтобы получить представление о том, как формула ИНДЕКС работает с реальными данными, взгляните на следующий пример:

Вместо того, чтобы вводить в формулу номера строк и столбцов, вы можете указать ссылки на ячейки, чтобы получить более универсальную формулу: 

=ИНДЕКС(C2:F11;I1;I2)

Итак, эта формула ИНДЕКС возвращает количество товаров точно на пересечении номера товара, указанного в ячейке I1 (номер_строки), и номера недели, введенного в ячейке I2 (номер_столбца).

Примечание. Использование абсолютных ссылок ($C$2:$F$11) вместо относительных ссылок (C2:F11) в аргументе массива упрощает копирование формулы в другие ячейки. Кроме того, вы можете преобразовать диапазон в таблицу (Ctrl + Т) и обращаться к нему по имени таблицы.

Что нужно помнить

  1. Если аргумент массива состоит только из одной строки или столбца, вы можете указать или не указать соответствующий аргумент номер_строки или номер_столбца.
  2. Если аргумент массива включает более одной строки, а номер_строки опущен или равен 0, функция ИНДЕКС возвращает массив всего столбца. Точно так же, если массив включает более одного столбца, а аргумент номер_столбца опущен или равен 0, формула ИНДЕКС возвращает всю строку. Вот пример формулы, демонстрирующий такое поведение.
  3. Аргументы номер_строки и номер_столбца должны ссылаться на ячейку в массиве; в противном случае формула ИНДЕКС вернет ошибку #ССЫЛКА!.

Форма ИНДЕКС в виде ссылки

Ссылочная форма функции ИНДЕКС Excel возвращает ссылку на ячейку на пересечении указанной строки и столбца.

ИНДЕКС(ссылка, номер_строки, [номер_столбца], [номер_области] )

  • ссылка — это один или несколько диапазонов.

Если вы вводите более одного диапазона, разделите диапазоны точкой с запятой и заключите аргумент ссылки в круглые скобки, например (A1:B5; D1:F5).

Если каждый диапазон в ссылке содержит только одну строку или столбец, соответствующий аргумент номер_строки или номер_столбца является необязательным.

  • номер_строки – порядковый номер строки в диапазоне, из которого возвращается ссылка на ячейку, аналогично форме массива.
  • номер_столбца — порядковый номер столбца, из которого возвращается ссылка на ячейку, также работает аналогично форме массива.
  • номер_области — необязательный параметр, указывающий, какой диапазон из ссылочного аргумента использовать. Если он не указан, формула ИНДЕКС вернет результат для первого диапазона, указанного в ссылке.

Например, формула =ИНДЕКС((B2:F4;B8:F11);3;2;2) возвращает значение ячейки С10, которая находится на пересечении 3-й строки и 2-го столбца во второй области (B8:F11).

Что нужно помнить о функции ИНДЕКС в форме ссылки

  1. Если аргумент номер_строки или номер_столбца равен нулю (0), формула ИНДЕКС возвращает ссылку для всего столбца или строки соответственно.
  2. Если и номер_строки, и номер_столбца опущены, функция ИНДЕКС возвращает область, указанную в аргументе номер_области.
  3. Все аргументы  (номер_строки, номер_столбца и номер_области) должны ссылаться на ячейку в пределах заданного диапазона. В противном случае формула ИНДЕКС вернет ошибку #ССЫЛКА! 

Обе формулы ИНДЕКС, которые мы обсуждали до сих пор, очень просты и служат только для иллюстрации. Ваши реальные формулы, вероятно, будут намного сложнее. Поэтому давайте рассмотрим несколько наиболее эффективных способов использования ИНДЕКС в Excel.

Как использовать функцию ИНДЕКС в Excel — примеры формул

Возможно, сама по себе функция ИНДЕКС в Excel не имеет большого практического применения, но в сочетании с другими функциями, такими как ПОИСКПОЗ или СЧËТ, она может создавать очень мощные формулы.

Далее во всех наших формулах ИНДЕКС (кроме последней) мы будем использовать приведенные ниже данные. 

1. Получение N-го элемента из списка

Это основное использование функции ИНДЕКС и простейшая её формула. Чтобы получить определенный элемент из списка, вы просто пишете:  =ИНДЕКС(диапазон; n),  где диапазон — это диапазон ячеек или именованный диапазон, а n — позиция элемента, который вы хотите из него получить.

Чтобы получить значение ячейки на пересечении определенной строки и столбца, вы используете тот же подход с той лишь разницей, что вы указываете и номер строки, и номер столбца. На самом деле, вы уже видели такую ​​формулу в действии, когда мы обсуждали форму массива функции ИНДЕКС .

И вот еще один пример. В нашем образце таблицы, чтобы найти четвертую по величине планету в Солнечной системе, вы сортируете таблицу по столбцу Диаметр и используете следующую формулу ИНДЕКС:

=ИНДЕКС(A5:E13;4;1)

  • A5:E13 — это ссылка на диапазон с данными.
  • Номер_строки равен 4, потому что вы ищете четвертый элемент в списке,
  • Номер_столбца равен 1, потому что мы хотим извлечь имя планеты.

Естественно, вы можете использовать ссылку на ячейку в аргументах номер_строки и/или номер_столбца, чтобы сделать вашу формулу более универсальной, как показано на скриншоте ниже:

Кроме того, вы можете не сортировать таблицу вручную, а сделать это при помощи формулы.

=ИНДЕКС(СОРТ(A5:E13;3;-1);B1;1)

Функция СОРТ сортирует таблицу по третьему столбцу в порядке убывания. Ну а затем ИНДЕКС делает всё остальное.

2. Получение всех значений в строке или столбце

Помимо извлечения одной ячейки, функция ИНДЕКС может возвращать массив значений из всей строки или столбца . Чтобы получить все значения из определенного столбца, вы должны опустить аргумент номер_строки или установить его равным 0. Аналогичным образом, чтобы получить всю строку, вы передаете пустое значение или 0 в номер_столбца.

Такие формулы ИНДЕКС вряд ли можно использовать сами по себе, потому что Excel не может уместить массив значений, возвращаемых формулой, в одну ячейку, и вы получите ошибку #ЗНАЧ!. Однако, если вы используете ИНДЕКС в сочетании с другими функциями, такими как СУММ или СРЗНАЧ, вы получите отличные результаты.

Например, вы можете использовать следующую формулу для расчета средней температуры планет в Солнечной системе:

=СРЗНАЧ(ИНДЕКС(A4:E12;;4))

В приведенной выше формуле аргумент номер_столбца равен 4, потому что температура находится в четвертом столбце нашей таблицы. Параметр номер_строки опущен.

Аналогичным образом можно найти минимальную и максимальную температуры:

=МИН(ИНДЕКС(A4:E12;;4))

=МАКС(ИНДЕКС(A4:E12;;4))

И посчитаем общую массу планет (масса – второй столбец в таблице):

=СУММ(ИНДЕКС(A4:E12;;2))

С практической точки зрения функция ИНДЕКС в приведенной выше формуле лишняя. Вы можете просто написать =СРЗНАЧ(D4:D12) и получить те же результаты.

При работе с реальными данными эта функция может оказаться полезной как часть более сложных формул, которые вы используете для анализа данных.

К примеру, формула =СУММ(ИНДЕКС(A4:E12;;С1)) позволит вам подсчитывать сумму в том столбце, номер которого вы укажете в ячейке C1.

3. Использование ИНДЕКС с другими функциями (СУММ, СРЗНАЧ, МАКС, МИН)

Из предыдущих примеров у вас может сложиться впечатление, что формула ИНДЕКС возвращает значения, но на самом деле она возвращает ссылку на ячейку, содержащую значение. И этот пример демонстрирует, как эту возвращаемую ссылку можно использовать.

Поскольку результат формулы ИНДЕКС является ссылкой, мы можем использовать его в других функциях для создания динамического диапазона. Звучит запутанно? Сейчас поясним.

Предположим, у вас есть формула =СРЗНАЧ(D4:D12), которая возвращает среднее значений в ячейках D4:D12. Вместо того, чтобы писать диапазон непосредственно в формуле, вы можете заменить либо D4, либо D12, либо их оба, функцией ИНДЕКС, например:

=СРЗНАЧ(D4 : ИНДЕКС(D1:D20,12))

Обе приведенные выше формулы дадут один и тот же результат, поскольку функция ИНДЕКС также возвращает ссылку на ячейку В12 (номер строки равен 12, номер столбца опущен). Разница в том, что диапазон формулы СРЗНАЧ / ИНДЕКС является динамическим, и как только вы измените аргумент номер_строки в ИНДЕКС, то диапазон, обрабатываемый функцией СРЗНАЧ, также изменится, и формула вернет другой результат.

По-видимому, такое использование формулы ИНДЕКС кажется слишком сложным и не всегда рациональным и логичным. Но этот подход имеет важное практическое применение, как показано в следующих примерах.

Пример 1. Вычислить среднее значение первых N элементов в списке

Допустим, вы хотите узнать средний диаметр N самых больших планет в солнечной системе. 

Количество позиций, которые мы будем использовать для расчета, указываем в ячейке В1.

Затем вы сортируете таблицу по столбцу диаметра от наибольшего к наименьшему и используете следующую формулу расчёта среднего значения:

=СРЗНАЧ(C5:ИНДЕКС(C5:C13;B1))

Как видите, количество значений для расчета среднего мы можем выбирать, не корректируя саму формулу

Пример 2. Сумма элементов между указанными двумя элементами

Если вы хотите определить элементы верхней и нижней границы в своей формуле, вам просто нужно использовать две функции ИНДЕКС, чтобы вернуть первый и последний элемент, которые вам нужны.

Например, следующая формула при помощи функции СУММ возвращает сумму значений в столбце Масса между двумя элементами, указанными в ячейках B1 и Е1:

=СУММ(ИНДЕКС(B5:B13;B1):ИНДЕКС(B5:B13;E1))

4. Формула ИНДЕКС для создания динамических диапазонов и раскрывающихся списков

Как это часто бывает, когда вы начинаете упорядочивать данные на листе, вы можете не знать, сколько записей у вас в конечном итоге будет. Это не относится к нашей таблице планет, которая кажется полной, но кто знает…

В любом случае, если у вас есть изменяющееся количество элементов в данном столбце, скажем, от A1 до An , вы можете создать динамический именованный диапазон , включающий все ячейки с данными. При этом вы хотите, чтобы диапазон корректировался автоматически по мере добавления новых элементов или удаления некоторых из существующих. Например, если у вас сейчас 10 элементов, ваш именованный диапазон будет A1:A10. Если вы добавите новую запись, именованный диапазон автоматически расширится до A1:A11, а если вы передумаете и удалите эти вновь добавленные данные, диапазон автоматически вернется к A1:A10.

Основное преимущество этого подхода заключается в том, что вам не нужно постоянно обновлять все формулы в книге, чтобы убедиться, что они относятся к правильным диапазонам.

Одним из способов определения динамического диапазона является использование функции Excel СМЕЩ :

=СМЕЩ($A$2; 0; 0; СЧЁТЗ($A1:$A100)-1; 1)

Другим возможным решением является использование ИНДЕКС Excel вместе с СЧËТЗ:

=$A$2:ИНДЕКС($A2:$A100; СЧЁТЗ($A2:$A100))

В обеих формулах A2 — это ячейка, содержащая первый элемент списка. Динамический диапазон, создаваемый обеими формулами, будет идентичным.

Разница заключается в подходах. В то время как функция СМЕЩ перемещается от начальной точки на определенное количество строк и/или столбцов, то ИНДЕКС находит ячейку на пересечении определенной строки и столбца. Функция СЧËТЗ, используемая в обеих формулах, получает количество непустых ячеек в интересующем нас столбце.

В этом примере в столбце A 9 непустых ячеек, поэтому СЧËТЗ возвращает 9. Следовательно, ИНДЕКС возвращает $A$9, то есть последнюю использованную ячейку в столбце A (обычно ИНДЕКС возвращает значение, но в этой формуле оператор ссылки (:) заставляет его вернуть ссылку). И поскольку $A$1 является нашей отправной точкой, конечным результатом формулы будет диапазон $A$1:$A$9.

На следующем рисунке показано, как можно использовать такую ​​формулу ИНДЕКС для создания динамического выпадающего списка.

ПримечаниеСамый простой способ создать динамически обновляемый выпадающий список — сделать именованный список на основе таблицы Excel. В этом случае вам не понадобятся сложные формулы, поскольку таблицы Excel сами по себе являются динамическими диапазонами.

Вы также можете использовать функцию ИНДЕКС для создания зависимых раскрывающихся списков, и в следующем руководстве объясняются все необходимые шаги: Создание каскадного раскрывающегося списка в Excel .

5. Мощный поиск с ИНДЕКС/ПОИСКПОЗ

Выполнение вертикального поиска — вот где функция ИНДЕКС действительно великолепна. Если вы когда-либо пробовали использовать функцию ВПР Excel , вы хорошо знаете ее многочисленные ограничения, такие как невозможность извлечения значений из столбцов слева от столбца поиска или ограничение в 255 символов для значения поиска.

Связка ИНДЕКС/ПОИСКПОЗ во многих отношениях превосходит ВПР:

  • Никаких проблем с «левым» ВПР.
  • Нет ограничений на размер искомого значения.
  • Сортировка не требуется (ВПР с приблизительным совпадением требует сортировки столбца подстановки в порядке возрастания).
  • Вы можете вставлять и удалять столбцы в таблице, не обновляя каждую связанную формулу.
  • И последнее, но не менее важное: ИНДЕКС/ПОИСКПОЗ не замедляет работу Excel, как это происходит, если использовать несколько формул ВПР в большой таблице.

Вы используете ИНДЕКС / ПОИСКПОЗ следующим образом:

=ИНДЕКС ( столбец для возврата значения , (ПОИСКПОЗ ( искомое значение , столбец для поиска , 0))

Например, по коду заказа мы можем найти название товара. При этом функция ПОИСКПОЗ ищет совпадение с кодами заказа, а затем передает номер найденной позиции в функцию ИНДЕКС. Та же в свою очередь извлекает соответствующее значение из переданного ей диапазона.

Таким образом организуется так называемый «левый» поиск, когда нужно извлечь значение из столбца, находящегося слева от столбца поиска. Функция ВПР сделать это не может. Более подробно о «левом» поиске читайте в этой статье.

Дополнительные советы и примеры формул см. в руководстве по Excel ИНДЕКС/ПОИСКПОЗ .

6. Формула ИНДЕКС для получения одного диапазона из списка диапазонов

Еще одно умное и эффективное использование функции ИНДЕКС в Excel — это возможность получить один диапазон из списка диапазонов.

Предположим, у вас есть несколько списков (например, сведения о еженедельных продажах). Вы можете рассчитать среднее значение или суммировать значения в любом выбранном диапазоне с помощью одной формулы.

Вы можете использовать следующую формулу индекса для расчета суммы продаж в выбранном диапазоне:

=СУММ(ИНДЕКС((C2:C11;D2:D11;E2:E11;F2:F11);;;I1))

Обратите внимание, что сейчас мы используем  функцию ИНДЕКС в виде ссылки. Число в последнем аргументе (номер_области) сообщает формуле, какой именно диапазон выбрать.

На скриншоте ниже для номера диапазона (ячейка I1) установлено значение 2. Поэтому формула вычисляет сумму продаж за вторую неделю. Выбран второй по счёту диапазон в списке – D2:D11.

Чтобы сделать формулу еще более удобной для пользователя, вы можете использовать проверку данных и создать в ячейке I2 выпадающий список с номерами недель, чтобы предотвратить ошибки и опечатки:

Вот несколько основных способов применения формулы ИНДЕКС в Excel. 

Я надеюсь, что эти примеры показали вам, как использовать потенциал функции ИНДЕКС в ваших рабочих листах. Спасибо за чтение!


Функция

ИНДЕКС(

)

, английский вариант INDEX(),

возвращает значение из диапазона ячеек по номеру строки и столбца. Например, формула

=ИНДЕКС(A9:A12;2)

вернет значение из ячейки

А10

, т.е. из ячейки расположенной во второй строке диапазона.

Синтаксис функции


ИНДЕКС

(массив; номер_строки; номер_столбца)


Массив

— ссылка на диапазон ячеек.


Номер_строки

— номер строки в массиве, из которой требуется возвратить значение. Если аргумент «номер_строки» опущен, аргумент «номер_столбца» является обязательным.


Номер_столбца

— номер столбца в массиве, из которого требуется возвратить значение. Если аргумент «номер_столбца» опущен, аргумент «номер_строки» является обязательным.

Если используются оба аргумента — и «номер_строки», и «номер_столбца», — то функция

ИНДЕКС()

возвращает значение, находящееся в ячейке на пересечении указанных строки и столбца.

Значения аргументов «номер_строки» и «номер_столбца» должны указывать на ячейку внутри заданного массива; в противном случае функция

ИНДЕКС()

возвращает значение ошибки #ССЫЛКА! Например, формула

=ИНДЕКС(A2:A13;22)

вернет ошибку, т.к. в диапазоне

А2:А13

только 12 строк.

Значение из заданной строки диапазона

Пусть имеется одностолбцовый диапазон

А6:А9.

Выведем значение из 2-й строки диапазона, т.е. значение

Груши

. Это можно сделать с помощью формулы

=ИНДЕКС(A6:A9;2)

Если диапазон горизонтальный (расположен в одной строке, например,

А6:D6

), то формула для вывода значения из 2-го столбца будет выглядеть так

=ИНДЕКС(A6:D6;;2)

Значение из заданной строки и столбца таблицы

Пусть имеется таблица в диапазоне

А6:B9.

Выведем значение, расположенное в 3-й строке и 2-м столбце таблицы, т.е. значение

200

. Это можно сделать с помощью формулы

=ИНДЕКС(A6:B9;3;2)

Использование функции в формулах массива

Если задать для аргумента «номер_строки» или «номер_столбца» значение 0, функция

ИНДЕКС()

возвратит массив значений для целого столбца или, соответственно, целой строки (не всего столбца/строки листа, а только столбца/строки входящего в массив). Чтобы использовать массив значений, введите функцию

ИНДЕКС()

как

формулу массива

.

Пусть имеется одностолбцовый диапазон

А6:А9.

Выведем 3 первых значения из этого диапазона, т.е. на

А6

,

А7

,

А8

. Для этого выделите 3 ячейки (

А21

,

А22

,

А23

), в

Строку формул

введите формулу

=ИНДЕКС(A6:A9;0)

, затем нажмите

CTRL+SHIFT+ENTER

.

Зачем это нужно? Теперь удалить по отдельности значения из ячеек

А21

,

А22

,

А23

не удастся, мы получим предупреждение «нельзя изменять часть массива».

Хотя можно просто ввести в этих 3-х ячейках ссылки на диапазон

А6:А8.

Выделите 3 ячейки и введите формулу

=A6:A8.

Затем нажмите

CTRL+SHIFT+ENTER

и получим тот же результат.

Использование массива констант

Вместо ссылки на диапазон можно использовать

массив констант

:

Формула

=ИНДЕКС({«первый»:»второй»:»третий»:»четвертый»};4)

вернет текстовое значение

четвертый

.

ПОИСКПОЗ() + ИНДЕКС()

Функция

ИНДЕКС()

часто используется в связке с функцией

ПОИСКПОЗ()

, которая возвращает позицию (строку) содержащую искомое значение. Это позволяет создать формулу, аналогичную функции

ВПР()

.

Формула

=ВПР(«яблоки»;A35:B38;2;0)

аналогична формуле

=ИНДЕКС(B35:B38;ПОИСКПОЗ(«яблоки»;A35:A38;0))

которая извлекает цену товара

Яблоки

из таблицы, размещенную в диапазоне

A35:B38

Связка

ПОИСКПОЗ()

+

ИНДЕКС()

даже гибче, чем функция

ВПР()

, т.к. с помощью ее можно, например, определить товар с заданной ценой (обратная задача, так называемый «левый ВПР()»). Формула

=ИНДЕКС(A35:A38;ПОИСКПОЗ(200;B35:B38;0))

определяет товар с ценой 200. Если товаров с такой ценой несколько, то будет выведен первый сверху.

Ссылочная форма

Функция

ИНДЕКС()

позволяет использовать так называемую ссылочную форму. Поясним на примере.

Пусть имеется диапазон с числами (

А2:А10

) Необходимо найти сумму первых 2-х, 3-х, …9 значений. Конечно, можно написать несколько формул

=СУММ(А2:А3)

,

=СУММ(А2:А4)

и т.д. Но, записав формулу ввиде:

=СУММ(A2:ИНДЕКС(A2:A10;4))

получим универсальное решение, в котором требуется изменять только последний аргумент (если в формуле выше вместо 4 ввести 5, то будет подсчитана сумма первых 5-и значений).

Использование функции

ИНДЕКС()

в этом примере принципиально отличается от примеров рассмотренных выше, т.к. функция возвращает не само значение, а ссылку (адрес ячейки) на значение. Вышеуказанная формула

=СУММ(A2:ИНДЕКС(A2:A10;4))

эквивалентна формуле

=СУММ(A2:A5)

Аналогичный результат можно получить используя функцию

СМЕЩ()

=СУММ(СМЕЩ(A2;;;4))


Теперь более сложный пример, с областями.

Пусть имеется таблица продаж нескольких товаров по полугодиям.

Задав

Товар

,

год

и

полугодие

, можно вывести соответствующий объем продаж с помощью формулы

=ИНДЕКС((B9:C12;D9:E12;F9:G12);B15;A19;B17)

Вся таблица как бы разбита на 3 подтаблицы (области), соответствующие отдельным годам:

B9:C12

;

D9:E12

;

F9:G12

. Задавая номер строки, столбца (в подтаблице) и номер области, можно вывести соответствующий объем продаж. В

файле примера

, выбранные строка и столбец выделены цветом с помощью

Условного форматирования

.

How to get the row or column number of the current cell or any other cell in Excel.

This tutorial covers important functions that allow you to do everything from alternate row and column shading to incrementing values at specified intervals and much more.

We will use the ROW and COLUMN function for this.  Here is an example of the output from these functions.

Though this doesn’t look like much, these functions allow for the creation of powerful formulas when combined with other functions.  Now, let’s look at how to create them.

Get a Cell’s Row Number

Syntax

This function returns the number of the row that a particular cell is in.

If you leave the function empty, it will return the row number for the current cell in which this function has been placed.

If you put a cell reference within this function, it will return the row number for that cell reference.

This example would return 1 since cell A1 is in row 1.  If it was =ROW(C24) the function would return the number 24 because cell C24 is in row 24.

Examples

Now that you know how this function works, it may seem rather useless.  Here are links to two examples where this function is key.

Increment a Value Every X Number of Rows in Excel

Shade Every Other Row in Excel Quickly

Get a Cell’s Column Number

Syntax

This function returns the number of the column that a particular cell is in.  It counts from left to right, where A is 1 and B is 2 and so on.

If you leave the function empty, it will return the column number for the current cell in which this function has been placed.

If you put a cell reference within this function, it will return the column number for that cell reference.

This example would return 1 since cell A1 is in row 1.  If it was =COLUMN (C24) the function would return the number 3 because cell C24 is in column number 3.

Examples

The COLUMN function works just like the ROW function does except that it works on columns, going left to right, whereas the ROW function works on rows, going up and down.

As such, almost every example where ROW is used could be converted to use COLUMN based on your needs.

Notes

The ROW and COLUMN functions are building blocks in that they help you create more complex formulas in Excel.  Alone, these functions are pretty much worthless, but, if you can memorize them and keep them for later, you will start to find more and more uses for them when working in large data sets.  The examples provided above in the ROW section cover only two of many different ways you can use these functions to create more powerful and helpful spreadsheets.

Similar Content on TeachExcel

Sum Values from Every X Number of Rows in Excel

Tutorial: Add values from every x number of rows in Excel. For instance, add together every other va…

Formulas to Remove First or Last Character from a Cell in Excel

Tutorial: Formulas that allow you to quickly and easily remove the first or last character from a ce…

Formula to Delete the First or Last Word from a Cell in Excel

Tutorial:
Excel formula to delete the first or last word from a cell.
You can copy and paste the fo…

Reverse the Contents of a Cell in Excel — UDF

Macro: Reverse cell contents with this free Excel UDF (user defined function). This will mir…

Excel Function to Remove All Text OR All Numbers from a Cell

Tutorial: How to create and use a function that removes all text or all numbers from a cell, whichev…

Get the First Word from a Cell in Excel

Tutorial: How to use a formula to get the first word from a cell in Excel. This works for a single c…

Subscribe for Weekly Tutorials

BONUS: subscribe now to download our Top Tutorials Ebook!

Этот учебник рассказывает о главных преимуществах функций ИНДЕКС и ПОИСКПОЗ в Excel, которые делают их более привлекательными по сравнению с ВПР. Вы увидите несколько примеров формул, которые помогут Вам легко справиться со многими сложными задачами, перед которыми функция ВПР бессильна.

В нескольких недавних статьях мы приложили все усилия, чтобы разъяснить начинающим пользователям основы функции ВПР и показать примеры более сложных формул для продвинутых пользователей. Теперь мы попытаемся, если не отговорить Вас от использования ВПР, то хотя бы показать альтернативные способы реализации вертикального поиска в Excel.

Зачем нам это? – спросите Вы. Да, потому что ВПР – это не единственная функция поиска в Excel, и её многочисленные ограничения могут помешать Вам получить желаемый результат во многих ситуациях. С другой стороны, функции ИНДЕКС и ПОИСКПОЗ – более гибкие и имеют ряд особенностей, которые делают их более привлекательными, по сравнению с ВПР.

ИНДЕКС и ПОИСКПОЗ в Excel

  • Базовая информация об ИНДЕКС и ПОИСКПОЗ
  • Используем функции ИНДЕКС и ПОИСКПОЗ в Excel
  • Преимущества ИНДЕКС и ПОИСКПОЗ перед ВПР
  • ИНДЕКС и ПОИСКПОЗ – примеры формул
    • Как находить значения, которые находятся слева
    • Вычисления при помощи ИНДЕКС и ПОИСКПОЗ
    • Поиск по известным строке и столбцу
    • Поиск по нескольким критериям
    • ИНДЕКС и ПОИСКПОЗ в сочетании с ЕСЛИОШИБКА

Содержание

  1. Базовая информация об ИНДЕКС и ПОИСКПОЗ
  2. ИНДЕКС – синтаксис и применение функции
  3. ПОИСКПОЗ – синтаксис и применение функции
  4. Как использовать ИНДЕКС и ПОИСКПОЗ в Excel
  5. Почему ИНДЕКС/ПОИСКПОЗ лучше, чем ВПР?
  6. 4 главных преимущества использования ПОИСКПОЗ/ИНДЕКС в Excel:
  7. ИНДЕКС и ПОИСКПОЗ – примеры формул
  8. Как выполнить поиск с левой стороны, используя ПОИСКПОЗ и ИНДЕКС
  9. Вычисления при помощи ИНДЕКС и ПОИСКПОЗ в Excel (СРЗНАЧ, МАКС, МИН)
  10. О чём нужно помнить, используя функцию СРЗНАЧ вместе с ИНДЕКС и ПОИСКПОЗ
  11. Как при помощи ИНДЕКС и ПОИСКПОЗ выполнять поиск по известным строке и столбцу
  12. Поиск по нескольким критериям с ИНДЕКС и ПОИСКПОЗ
  13. ИНДЕКС и ПОИСКПОЗ в сочетании с ЕСЛИОШИБКА в Excel

Базовая информация об ИНДЕКС и ПОИСКПОЗ

Так как задача этого учебника – показать возможности функций ИНДЕКС и ПОИСКПОЗ для реализации вертикального поиска в Excel, мы не будем задерживаться на их синтаксисе и применении.

Приведём здесь необходимый минимум для понимания сути, а затем разберём подробно примеры формул, которые показывают преимущества использования ИНДЕКС и ПОИСКПОЗ вместо ВПР.

ИНДЕКС – синтаксис и применение функции

Функция INDEX (ИНДЕКС) в Excel возвращает значение из массива по заданным номерам строки и столбца. Функция имеет вот такой синтаксис:

INDEX(array,row_num,[column_num])
ИНДЕКС(массив;номер_строки;[номер_столбца])

Каждый аргумент имеет очень простое объяснение:

  • array (массив) – это диапазон ячеек, из которого необходимо извлечь значение.
  • row_num (номер_строки) – это номер строки в массиве, из которой нужно извлечь значение. Если не указан, то обязательно требуется аргумент column_num (номер_столбца).
  • column_num (номер_столбца) – это номер столбца в массиве, из которого нужно извлечь значение. Если не указан, то обязательно требуется аргумент row_num (номер_строки)

Если указаны оба аргумента, то функция ИНДЕКС возвращает значение из ячейки, находящейся на пересечении указанных строки и столбца.

Вот простейший пример функции INDEX (ИНДЕКС):

=INDEX(A1:C10,2,3)
=ИНДЕКС(A1:C10;2;3)

Формула выполняет поиск в диапазоне A1:C10 и возвращает значение ячейки во 2-й строке и 3-м столбце, то есть из ячейки C2.

Очень просто, правда? Однако, на практике Вы далеко не всегда знаете, какие строка и столбец Вам нужны, и поэтому требуется помощь функции ПОИСКПОЗ.

ПОИСКПОЗ – синтаксис и применение функции

Функция MATCH (ПОИСКПОЗ) в Excel ищет указанное значение в диапазоне ячеек и возвращает относительную позицию этого значения в диапазоне.

Например, если в диапазоне B1:B3 содержатся значения New-York, Paris, London, тогда следующая формула возвратит цифру 3, поскольку «London» – это третий элемент в списке.

=MATCH("London",B1:B3,0)
=ПОИСКПОЗ("London";B1:B3;0)

Функция MATCH (ПОИСКПОЗ) имеет вот такой синтаксис:

MATCH(lookup_value,lookup_array,[match_type])
ПОИСКПОЗ(искомое_значение;просматриваемый_массив;[тип_сопоставления])

  • lookup_value (искомое_значение) – это число или текст, который Вы ищите. Аргумент может быть значением, в том числе логическим, или ссылкой на ячейку.
  • lookup_array (просматриваемый_массив) – диапазон ячеек, в котором происходит поиск.
  • match_type (тип_сопоставления) – этот аргумент сообщает функции ПОИСКПОЗ, хотите ли Вы найти точное или приблизительное совпадение:
    • 1 или не указан – находит максимальное значение, меньшее или равное искомому. Просматриваемый массив должен быть упорядочен по возрастанию, то есть от меньшего к большему.
    • 0 – находит первое значение, равное искомому. Для комбинации ИНДЕКС/ПОИСКПОЗ всегда нужно точное совпадение, поэтому третий аргумент функции ПОИСКПОЗ должен быть равен 0.
    • -1 – находит наименьшее значение, большее или равное искомому значению. Просматриваемый массив должен быть упорядочен по убыванию, то есть от большего к меньшему.

На первый взгляд, польза от функции ПОИСКПОЗ вызывает сомнение. Кому нужно знать положение элемента в диапазоне? Мы хотим знать значение этого элемента!

Позвольте напомнить, что относительное положение искомого значения (т.е. номер строки и/или столбца) – это как раз то, что мы должны указать для аргументов row_num (номер_строки) и/или column_num (номер_столбца) функции INDEX (ИНДЕКС). Как Вы помните, функция ИНДЕКС может возвратить значение, находящееся на пересечении заданных строки и столбца, но она не может определить, какие именно строка и столбец нас интересуют.

Как использовать ИНДЕКС и ПОИСКПОЗ в Excel

Теперь, когда Вам известна базовая информация об этих двух функциях, полагаю, что уже становится понятно, как функции ПОИСКПОЗ и ИНДЕКС могут работать вместе. ПОИСКПОЗ определяет относительную позицию искомого значения в заданном диапазоне ячеек, а ИНДЕКС использует это число (или числа) и возвращает результат из соответствующей ячейки.

Ещё не совсем понятно? Представьте функции ИНДЕКС и ПОИСКПОЗ в таком виде:

=INDEX(столбец из которого извлекаем,(MATCH (искомое значение,столбец в котором ищем,0))
=ИНДЕКС(столбец из которого извлекаем;(ПОИСКПОЗ(искомое значение;столбец в котором ищем;0))

Думаю, ещё проще будет понять на примере. Предположим, у Вас есть вот такой список столиц государств:

ИНДЕКС и ПОИСКПОЗ в Excel

Давайте найдём население одной из столиц, например, Японии, используя следующую формулу:

=INDEX($D$2:$D$10,MATCH("Japan",$B$2:$B$10,0))
=ИНДЕКС($D$2:$D$10;ПОИСКПОЗ("Japan";$B$2:$B$10;0))

Теперь давайте разберем, что делает каждый элемент этой формулы:

  • Функция MATCH (ПОИСКПОЗ) ищет значение «Japan» в столбце B, а конкретно – в ячейках B2:B10, и возвращает число 3, поскольку «Japan» в списке на третьем месте.
  • Функция INDEX (ИНДЕКС) использует 3 для аргумента row_num (номер_строки), который указывает из какой строки нужно возвратить значение. Т.е. получается простая формула:

    =INDEX($D$2:$D$10,3)
    =ИНДЕКС($D$2:$D$10;3)

    Формула говорит примерно следующее: ищи в ячейках от D2 до D10 и извлеки значение из третьей строки, то есть из ячейки D4, так как счёт начинается со второй строки.

Вот такой результат получится в Excel:

ИНДЕКС и ПОИСКПОЗ в Excel

Важно! Количество строк и столбцов в массиве, который использует функция INDEX (ИНДЕКС), должно соответствовать значениям аргументов row_num (номер_строки) и column_num (номер_столбца) функции MATCH (ПОИСКПОЗ). Иначе результат формулы будет ошибочным.

Стоп, стоп… почему мы не можем просто использовать функцию VLOOKUP (ВПР)? Есть ли смысл тратить время, пытаясь разобраться в лабиринтах ПОИСКПОЗ и ИНДЕКС?

=VLOOKUP("Japan",$B$2:$D$2,3)
=ВПР("Japan";$B$2:$D$2;3)

В данном случае – смысла нет! Цель этого примера – исключительно демонстрационная, чтобы Вы могли понять, как функции ПОИСКПОЗ и ИНДЕКС работают в паре. Последующие примеры покажут Вам истинную мощь связки ИНДЕКС и ПОИСКПОЗ, которая легко справляется с многими сложными ситуациями, когда ВПР оказывается в тупике.

Почему ИНДЕКС/ПОИСКПОЗ лучше, чем ВПР?

Решая, какую формулу использовать для вертикального поиска, большинство гуру Excel считают, что ИНДЕКС/ПОИСКПОЗ намного лучше, чем ВПР. Однако, многие пользователи Excel по-прежнему прибегают к использованию ВПР, т.к. эта функция гораздо проще. Так происходит, потому что очень немногие люди до конца понимают все преимущества перехода с ВПР на связку ИНДЕКС и ПОИСКПОЗ, а тратить время на изучение более сложной формулы никто не хочет.

Далее я попробую изложить главные преимущества использования ПОИСКПОЗ и ИНДЕКС в Excel, а Вы решите – остаться с ВПР или переключиться на ИНДЕКС/ПОИСКПОЗ.

4 главных преимущества использования ПОИСКПОЗ/ИНДЕКС в Excel:

1. Поиск справа налево. Как известно любому грамотному пользователю Excel, ВПР не может смотреть влево, а это значит, что искомое значение должно обязательно находиться в крайнем левом столбце исследуемого диапазона. В случае с ПОИСКПОЗ/ИНДЕКС, столбец поиска может быть, как в левой, так и в правой части диапазона поиска. Пример: Как находить значения, которые находятся слева покажет эту возможность в действии.

2. Безопасное добавление или удаление столбцов. Формулы с функцией ВПР перестают работать или возвращают ошибочные значения, если удалить или добавить столбец в таблицу поиска. Для функции ВПР любой вставленный или удалённый столбец изменит результат формулы, поскольку синтаксис ВПР требует указывать весь диапазон и конкретный номер столбца, из которого нужно извлечь данные.

Например, если у Вас есть таблица A1:C10, и требуется извлечь данные из столбца B, то нужно задать значение 2 для аргумента col_index_num (номер_столбца) функции ВПР, вот так:

=VLOOKUP("lookup value",A1:C10,2)
=ВПР("lookup value";A1:C10;2)

Если позднее Вы вставите новый столбец между столбцами A и B, то значение аргумента придется изменить с 2 на 3, иначе формула возвратит результат из только что вставленного столбца.

Используя ПОИСКПОЗ/ИНДЕКС, Вы можете удалять или добавлять столбцы к исследуемому диапазону, не искажая результат, так как определен непосредственно столбец, содержащий нужное значение. Действительно, это большое преимущество, особенно когда работать приходится с большими объёмами данных. Вы можете добавлять и удалять столбцы, не беспокоясь о том, что нужно будет исправлять каждую используемую функцию ВПР.

3. Нет ограничения на размер искомого значения. Используя ВПР, помните об ограничении на длину искомого значения в 255 символов, иначе рискуете получить ошибку #VALUE! (#ЗНАЧ!). Итак, если таблица содержит длинные строки, единственное действующее решение – это использовать ИНДЕКС/ПОИСКПОЗ.

Предположим, Вы используете вот такую формулу с ВПР, которая ищет в ячейках от B5 до D10 значение, указанное в ячейке A2:

=VLOOKUP(A2,B5:D10,3,FALSE)
=ВПР(A2;B5:D10;3;ЛОЖЬ)

Формула не будет работать, если значение в ячейке A2 длиннее 255 символов. Вместо неё Вам нужно использовать аналогичную формулу ИНДЕКС/ПОИСКПОЗ:

=INDEX(D5:D10,MATCH(TRUE,INDEX(B5:B10=A2,0),0))
=ИНДЕКС(D5:D10;ПОИСКПОЗ(ИСТИНА;ИНДЕКС(B5:B10=A2;0);0))

4. Более высокая скорость работы. Если Вы работаете с небольшими таблицами, то разница в быстродействии Excel будет, скорее всего, не заметная, особенно в последних версиях. Если же Вы работаете с большими таблицами, которые содержат тысячи строк и сотни формул поиска, Excel будет работать значительно быстрее, при использовании ПОИСКПОЗ и ИНДЕКС вместо ВПР. В целом, такая замена увеличивает скорость работы Excel на 13%.

Влияние ВПР на производительность Excel особенно заметно, если рабочая книга содержит сотни сложных формул массива, таких как ВПР+СУММ. Дело в том, что проверка каждого значения в массиве требует отдельного вызова функции ВПР. Поэтому, чем больше значений содержит массив и чем больше формул массива содержит Ваша таблица, тем медленнее работает Excel.

С другой стороны, формула с функциями ПОИСКПОЗ и ИНДЕКС просто совершает поиск и возвращает результат, выполняя аналогичную работу заметно быстрее.

ИНДЕКС и ПОИСКПОЗ – примеры формул

Теперь, когда Вы понимаете причины, из-за которых стоит изучать функции ПОИСКПОЗ и ИНДЕКС, давайте перейдём к самому интересному и увидим, как можно применить теоретические знания на практике.

Как выполнить поиск с левой стороны, используя ПОИСКПОЗ и ИНДЕКС

Любой учебник по ВПР твердит, что эта функция не может смотреть влево. Т.е. если просматриваемый столбец не является крайним левым в диапазоне поиска, то нет шансов получить от ВПР желаемый результат.

Функции ПОИСКПОЗ и ИНДЕКС в Excel гораздо более гибкие, и им все-равно, где находится столбец со значением, которое нужно извлечь. Для примера, снова вернёмся к таблице со столицами государств и населением. На этот раз запишем формулу ПОИСКПОЗ/ИНДЕКС, которая покажет, какое место по населению занимает столица России (Москва).

Как видно на рисунке ниже, формула отлично справляется с этой задачей:

=INDEX($A$2:$A$10,MATCH("Russia",$B$2:$B$10,0))
=ИНДЕКС($A$2:$A$10;ПОИСКПОЗ("Russia";$B$2:$B$10;0))

ИНДЕКС и ПОИСКПОЗ в Excel

Теперь у Вас не должно возникать проблем с пониманием, как работает эта формула:

  • Во-первых, задействуем функцию MATCH (ПОИСКПОЗ), которая находит положение «Russia» в списке:

    =MATCH("Russia",$B$2:$B$10,0))
    =ПОИСКПОЗ("Russia";$B$2:$B$10;0))

  • Далее, задаём диапазон для функции INDEX (ИНДЕКС), из которого нужно извлечь значение. В нашем случае это A2:A10.
  • Затем соединяем обе части и получаем формулу:

    =INDEX($A$2:$A$10;MATCH("Russia";$B$2:$B$10;0))
    =ИНДЕКС($A$2:$A$10;ПОИСКПОЗ("Russia";$B$2:$B$10;0))

Подсказка: Правильным решением будет всегда использовать абсолютные ссылки для ИНДЕКС и ПОИСКПОЗ, чтобы диапазоны поиска не сбились при копировании формулы в другие ячейки.

Вычисления при помощи ИНДЕКС и ПОИСКПОЗ в Excel (СРЗНАЧ, МАКС, МИН)

Вы можете вкладывать другие функции Excel в ИНДЕКС и ПОИСКПОЗ, например, чтобы найти минимальное, максимальное или ближайшее к среднему значение. Вот несколько вариантов формул, применительно к таблице из предыдущего примера:

1. MAX (МАКС). Формула находит максимум в столбце D и возвращает значение из столбца C той же строки:

=INDEX($C$2:$C$10,MATCH(MAX($D$2:I$10),$D$2:D$10,0))
=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(МАКС($D$2:I$10);$D$2:D$10;0))

Результат: Beijing

2. MIN (МИН). Формула находит минимум в столбце D и возвращает значение из столбца C той же строки:

=INDEX($C$2:$C$10,MATCH(MIN($D$2:I$10),$D$2:D$10,0))
=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(МИН($D$2:I$10);$D$2:D$10;0))

Результат: Lima

3. AVERAGE (СРЗНАЧ). Формула вычисляет среднее в диапазоне D2:D10, затем находит ближайшее к нему и возвращает значение из столбца C той же строки:

=INDEX($C$2:$C$10,MATCH(AVERAGE($D$2:D$10),$D$2:D$10,1))
=ИНДЕКС($C$2:$C$10;ПОИСКПОЗ(СРЗНАЧ($D$2:D$10);$D$2:D$10;1))

Результат: Moscow

О чём нужно помнить, используя функцию СРЗНАЧ вместе с ИНДЕКС и ПОИСКПОЗ

Используя функцию СРЗНАЧ в комбинации с ИНДЕКС и ПОИСКПОЗ, в качестве третьего аргумента функции ПОИСКПОЗ чаще всего нужно будет указывать 1 или -1 в случае, если Вы не уверены, что просматриваемый диапазон содержит значение, равное среднему. Если же Вы уверены, что такое значение есть, – ставьте 0 для поиска точного совпадения.

  • Если указываете 1, значения в столбце поиска должны быть упорядочены по возрастанию, а формула вернёт максимальное значение, меньшее или равное среднему.
  • Если указываете -1, значения в столбце поиска должны быть упорядочены по убыванию, а возвращено будет минимальное значение, большее или равное среднему.

В нашем примере значения в столбце D упорядочены по возрастанию, поэтому мы используем тип сопоставления 1. Формула ИНДЕКС/ПОИСКПОЗ возвращает «Moscow», поскольку величина населения города Москва – ближайшее меньшее к среднему значению (12 269 006).

ИНДЕКС и ПОИСКПОЗ в Excel

Как при помощи ИНДЕКС и ПОИСКПОЗ выполнять поиск по известным строке и столбцу

Эта формула эквивалентна двумерному поиску ВПР и позволяет найти значение на пересечении определённой строки и столбца.

В этом примере формула ИНДЕКС/ПОИСКПОЗ будет очень похожа на формулы, которые мы уже обсуждали в этом уроке, с одним лишь отличием. Угадайте каким?

Как Вы помните, синтаксис функции INDEX (ИНДЕКС) позволяет использовать три аргумента:

INDEX(array,row_num,[column_num])
ИНДЕКС(массив;номер_строки;[номер_столбца])

И я поздравляю тех из Вас, кто догадался!

Начнём с того, что запишем шаблон формулы. Для этого возьмём уже знакомую нам формулу ИНДЕКС/ПОИСКПОЗ и добавим в неё ещё одну функцию ПОИСКПОЗ, которая будет возвращать номер столбца.

=INDEX(Ваша таблица,(MATCH(значение для вертикального поиска,столбец, в котором искать,0)),(MATCH(значение для горизонтального поиска,строка в которой искать,0))
=ИНДЕКС(Ваша таблица,(MATCH(значение для вертикального поиска,столбец, в котором искать,0)),(MATCH(значение для горизонтального поиска,строка в которой искать,0))

Обратите внимание, что для двумерного поиска нужно указать всю таблицу в аргументе array (массив) функции INDEX (ИНДЕКС).

А теперь давайте испытаем этот шаблон на практике. Ниже Вы видите список самых населённых стран мира. Предположим, наша задача узнать население США в 2015 году.

ИНДЕКС и ПОИСКПОЗ в Excel

Хорошо, давайте запишем формулу. Когда мне нужно создать сложную формулу в Excel с вложенными функциями, то я сначала каждую вложенную записываю отдельно.

Итак, начнём с двух функций ПОИСКПОЗ, которые будут возвращать номера строки и столбца для функции ИНДЕКС:

  • ПОИСКПОЗ для столбца – мы ищем в столбце B, а точнее в диапазоне B2:B11, значение, которое указано в ячейке H2 (USA). Функция будет выглядеть так:

    =MATCH($H$2,$B$1:$B$11,0)
    =ПОИСКПОЗ($H$2;$B$1:$B$11;0)

    Результатом этой формулы будет 4, поскольку «USA» – это 4-ый элемент списка в столбце B (включая заголовок).

  • ПОИСКПОЗ для строки – мы ищем значение ячейки H3 (2015) в строке 1, то есть в ячейках A1:E1:

    =MATCH($H$3,$A$1:$E$1,0)
    =ПОИСКПОЗ($H$3;$A$1:$E$1;0)

    Результатом этой формулы будет 5, поскольку «2015» находится в 5-ом столбце.

Теперь вставляем эти формулы в функцию ИНДЕКС и вуаля:

=INDEX($A$1:$E$11,MATCH($H$2,$B$1:$B$11,0),MATCH($H$3,$A$1:$E$1,0))
=ИНДЕКС($A$1:$E$11;ПОИСКПОЗ($H$2;$B$1:$B$11;0);ПОИСКПОЗ($H$3;$A$1:$E$1;0))

Если заменить функции ПОИСКПОЗ на значения, которые они возвращают, формула станет легкой и понятной:

=INDEX($A$1:$E$11,4,5))
=ИНДЕКС($A$1:$E$11;4;5))

Эта формула возвращает значение на пересечении 4-ой строки и 5-го столбца в диапазоне A1:E11, то есть значение ячейки E4. Просто? Да!

ИНДЕКС и ПОИСКПОЗ в Excel

Поиск по нескольким критериям с ИНДЕКС и ПОИСКПОЗ

В учебнике по ВПР мы показывали пример формулы с функцией ВПР для поиска по нескольким критериям. Однако, существенным ограничением такого решения была необходимость добавлять вспомогательный столбец. Хорошая новость: формула ИНДЕКС/ПОИСКПОЗ может искать по значениям в двух столбцах, без необходимости создания вспомогательного столбца!

Предположим, у нас есть список заказов, и мы хотим найти сумму по двум критериям – имя покупателя (Customer) и продукт (Product). Дело усложняется тем, что один покупатель может купить сразу несколько разных продуктов, и имена покупателей в таблице на листе Lookup table расположены в произвольном порядке.

ИНДЕКС и ПОИСКПОЗ в Excel

Вот такая формула ИНДЕКС/ПОИСКПОЗ решает задачу:

{=INDEX('Lookup table'!$A$2:$C$13,MATCH(1,(A2='Lookup table'!$A$2:$A$13)*
(B2='Lookup table'!$B$2:$B$13),0),3)}

{=ИНДЕКС('Lookup table'!$A$2:$C$13;ПОИСКПОЗ(1;(A2='Lookup table'!$A$2:$A$13)*
(B2='Lookup table'!$B$2:$B$13);0);3)}

Эта формула сложнее других, которые мы обсуждали ранее, но вооруженные знанием функций ИНДЕКС и ПОИСКПОЗ Вы одолеете ее. Самая сложная часть – это функция ПОИСКПОЗ, думаю, её нужно объяснить первой.

MATCH(1,(A2='Lookup table'!$A$2:$A$13),0)*(B2='Lookup table'!$B$2:$B$13)
ПОИСКПОЗ(1;(A2='Lookup table'!$A$2:$A$13);0)*(B2='Lookup table'!$B$2:$B$13)

В формуле, показанной выше, искомое значение – это 1, а массив поиска – это результат умножения. Хорошо, что же мы должны перемножить и почему? Давайте разберем все по порядку:

  • Берем первое значение в столбце A (Customer) на листе Main table и сравниваем его со всеми именами покупателей в таблице на листе Lookup table (A2:A13).
  • Если совпадение найдено, уравнение возвращает 1 (ИСТИНА), а если нет – 0 (ЛОЖЬ).
  • Далее, мы делаем то же самое для значений столбца B (Product).
  • Затем перемножаем полученные результаты (1 и 0). Только если совпадения найдены в обоих столбцах (т.е. оба критерия истинны), Вы получите 1. Если оба критерия ложны, или выполняется только один из них – Вы получите 0.

Теперь понимаете, почему мы задали 1, как искомое значение? Правильно, чтобы функция ПОИСКПОЗ возвращала позицию только, когда оба критерия выполняются.

Обратите внимание: В этом случае необходимо использовать третий не обязательный аргумент функции ИНДЕКС. Он необходим, т.к. в первом аргументе мы задаем всю таблицу и должны указать функции, из какого столбца нужно извлечь значение. В нашем случае это столбец C (Sum), и поэтому мы ввели 3.

И, наконец, т.к. нам нужно проверить каждую ячейку в массиве, эта формула должна быть формулой массива. Вы можете видеть это по фигурным скобкам, в которые она заключена. Поэтому, когда закончите вводить формулу, не забудьте нажать Ctrl+Shift+Enter.

Если всё сделано верно, Вы получите результат как на рисунке ниже:

ИНДЕКС и ПОИСКПОЗ в Excel

ИНДЕКС и ПОИСКПОЗ в сочетании с ЕСЛИОШИБКА в Excel

Как Вы, вероятно, уже заметили (и не раз), если вводить некорректное значение, например, которого нет в просматриваемом массиве, формула ИНДЕКС/ПОИСКПОЗ сообщает об ошибке #N/A (#Н/Д) или #VALUE! (#ЗНАЧ!). Если Вы хотите заменить такое сообщение на что-то более понятное, то можете вставить формулу с ИНДЕКС и ПОИСКПОЗ в функцию ЕСЛИОШИБКА.

Синтаксис функции ЕСЛИОШИБКА очень прост:

IFERROR(value,value_if_error)
ЕСЛИОШИБКА(значение;значение_если_ошибка)

Где аргумент value (значение) – это значение, проверяемое на предмет наличия ошибки (в нашем случае – результат формулы ИНДЕКС/ПОИСКПОЗ); а аргумент value_if_error (значение_если_ошибка) – это значение, которое нужно возвратить, если формула выдаст ошибку.

Например, Вы можете вставить формулу из предыдущего примера в функцию ЕСЛИОШИБКА вот таким образом:

=IFERROR(INDEX($A$1:$E$11,MATCH($G$2,$B$1:$B$11,0),MATCH($G$3,$A$1:$E$1,0)),
"Совпадений не найдено. Попробуйте еще раз!")
=ЕСЛИОШИБКА(ИНДЕКС($A$1:$E$11;ПОИСКПОЗ($G$2;$B$1:$B$11;0);ПОИСКПОЗ($G$3;$A$1:$E$1;0));
"Совпадений не найдено. Попробуйте еще раз!")

И теперь, если кто-нибудь введет ошибочное значение, формула выдаст вот такой результат:

ИНДЕКС и ПОИСКПОЗ в Excel

Если Вы предпочитаете в случае ошибки оставить ячейку пустой, то можете использовать кавычки («»), как значение второго аргумента функции ЕСЛИОШИБКА. Вот так:

IFERROR(INDEX(массив,MATCH(искомое_значение,просматриваемый_массив,0),"")
ЕСЛИОШИБКА(ИНДЕКС(массив;ПОИСКПОЗ(искомое_значение;просматриваемый_массив;0);"")

Надеюсь, что хотя бы одна формула, описанная в этом учебнике, показалась Вам полезной. Если Вы сталкивались с другими задачами поиска, для которых не смогли найти подходящее решение среди информации в этом уроке, смело опишите свою проблему в комментариях, и мы все вместе постараемся решить её.

Оцените качество статьи. Нам важно ваше мнение:

Содержание

  • Использование функции ИНДЕКС
    • Способ 1: использование оператора ИНДЕКС для массивов
    • Способ 2: применение в комплексе с оператором ПОИСКПОЗ
    • Способ 3: обработка нескольких таблиц
    • Способ 4: вычисление суммы
  • Вопросы и ответы

Функция ИНДЕКС в Microsoft Excel

Одной из самых полезных функций программы Эксель является оператор ИНДЕКС. Он производит поиск данных в диапазоне на пересечении указанных строки и столбца, возвращая результат в заранее обозначенную ячейку. Но полностью возможности этой функции раскрываются при использовании её в сложных формулах в комбинации с другими операторами. Давайте рассмотрим различные варианты её применения.

Использование функции ИНДЕКС

Оператор ИНДЕКС относится к группе функций из категории «Ссылки и массивы». Он имеет две разновидности: для массивов и для ссылок.

Вариант для массивов имеет следующий синтаксис:

=ИНДЕКС(массив;номер_строки;номер_столбца)

При этом два последних аргумента в формуле можно использовать, как вместе, так и любой один из них, если массив одномерный. При многомерном диапазоне следует применять оба значения. Нужно также учесть, что под номером строки и столбца понимается не номер на координатах листа, а порядок внутри самого указанного массива.

Синтаксис для ссылочного варианта выглядит так:

=ИНДЕКС(ссылка;номер_строки;номер_столбца;[номер_области])

Тут точно так же можно использовать только один аргумент из двух: «Номер строки» или «Номер столбца». Аргумент «Номер области» вообще является необязательным и он применяется только тогда, когда в операции участвуют несколько диапазонов.

Таким образом, оператор ищет данные в установленном диапазоне при указании строки или столбца. Данная функция своими возможностями очень похожа на оператора ВПР, но в отличие от него может производить поиск практически везде, а не только в крайнем левом столбце таблицы.

Способ 1: использование оператора ИНДЕКС для массивов

Давайте, прежде всего, разберем на простейшем примере алгоритм использования оператора ИНДЕКС для массивов.

Имеем таблицу зарплат. В первом её столбце отображены фамилии работников, во втором – дата выплаты, а в третьем – величина суммы заработка. Нам нужно вывести имя работника в третьей строке.

  1. Выделяем ячейку, в которой будет выводиться результат обработки. Кликаем по значку «Вставить функцию», который размещен сразу слева от строки формул.
  2. Переход в Мастер функций в Microsoft Excel

  3. Происходит процедура активации Мастера функций. В категории «Ссылки и массивы» данного инструмента или «Полный алфавитный перечень» ищем наименование «ИНДЕКС». После того, как нашли этого оператора, выделяем его и щелкаем по кнопке «OK», которая размещается в нижней части окна.
  4. Мастер функций в Microsoft Excel

  5. Открывается небольшое окошко, в котором нужно выбрать один из типов функции: «Массив» или «Ссылка». Нужный нам вариант «Массив». Он расположен первым и по умолчанию выделен. Поэтому нам остается просто нажать на кнопку «OK».
  6. Выбор типа функции ИНДЕКС в Microsoft Excel

    Lumpics.ru

  7. Открывается окно аргументов функции ИНДЕКС. Как выше говорилось, у неё имеется три аргумента, а соответственно и три поля для заполнения.

    В поле «Массив» нужно указать адрес обрабатываемого диапазона данных. Его можно вбить вручную. Но для облегчения задачи мы поступим иначе. Ставим курсор в соответствующее поле, а затем обводим весь диапазон табличных данных на листе. После этого адрес диапазона тут же отобразится в поле.

    В поле «Номер строки» ставим цифру «3», так как по условию нам нужно определить третье имя в списке. В поле «Номер столбца» устанавливаем число «1», так как колонка с именами является первой в выделенном диапазоне.

    После того, как все указанные настройки совершены, щелкаем по кнопке «OK».

  8. Окно аргументов функции ИНДЕКС в Microsoft Excel

  9. Результат обработки выводится в ячейку, которая была указана в первом пункте данной инструкции. Именно выведенная фамилия является третьей в списке в выделенном диапазоне данных.

Результат обработки функции ИНДЕКС в Microsoft Excel

Мы разобрали применение функции ИНДЕКС в многомерном массиве (несколько столбцов и строк). Если бы диапазон был одномерным, то заполнение данных в окне аргументов было бы ещё проще. В поле «Массив» тем же методом, что и выше, мы указываем его адрес. В данном случае диапазон данных состоит только из значений в одной колонке «Имя». В поле «Номер строки» указываем значение «3», так как нужно узнать данные из третьей строки. Поле «Номер столбца» вообще можно оставить пустым, так как у нас одномерный диапазон, в котором используется только один столбец. Жмем на кнопку «OK».

Окно аргументов функции ИНДЕКС для одномерного массива в Microsoft Excel

Результат будет точно такой же, что и выше.

Результат обработки функции ИНДЕКС для одномерного массива в Microsoft Excel

Это был простейший пример, чтобы вы увидели, как работает данная функция, но на практике подобный вариант её использования применяется все-таки редко.

Урок: Мастер функций в Экселе

Способ 2: применение в комплексе с оператором ПОИСКПОЗ

На практике функция ИНДЕКС чаще всего применяется вместе с аргументом ПОИСКПОЗ. Связка ИНДЕКСПОИСКПОЗ является мощнейшим инструментом при работе в Эксель, который по своему функционалу более гибок, чем его ближайший аналог – оператор ВПР.

Основной задачей функции ПОИСКПОЗ является указание номера по порядку определенного значения в выделенном диапазоне.

Синтаксис оператора ПОИСКПОЗ такой:

=ПОИСКПОЗ(искомое_значение, просматриваемый_массив, [тип_сопоставления])

  • Искомое значение – это значение, позицию которого в диапазоне мы ищем;
  • Просматриваемый массив – это диапазон, в котором находится это значение;
  • Тип сопоставления – это необязательный параметр, который определяет, точно или приблизительно искать значения. Мы будем искать точные значения, поэтому данный аргумент не используется.

С помощью этого инструмента можно автоматизировать введение аргументов «Номер строки» и «Номер столбца» в функцию ИНДЕКС.

Посмотрим, как это можно сделать на конкретном примере. Работаем все с той же таблицей, о которой шла речь выше. Отдельно у нас имеется два дополнительных поля – «Имя» и «Сумма». Нужно сделать так, что при введении имени работника автоматически отображалась сумма заработанных им денег. Посмотрим, как это можно воплотить на практике, применив функции ИНДЕКС и ПОИСКПОЗ.

  1. Прежде всего, узнаем, какую заработную плату получает работник Парфенов Д. Ф. Вписываем его имя в соответствующее поле.
  2. Имя вписано в поле в Microsoft Excel

  3. Выделяем ячейку в поле «Сумма», в которой будет выводиться итоговый результат. Запускаем окно аргументов функции ИНДЕКС для массивов.

    В поле «Массив» вносим координаты столбца, в котором находятся суммы заработных плат работников.

    Поле «Номер столбца» оставляем пустым, так как мы используем для примера одномерный диапазон.

    А вот в поле «Номер строки» нам как раз нужно будет записать функцию ПОИСКПОЗ. Для её записи придерживаемся того синтаксиса, о котором шла речь выше. Сразу в поле вписываем наименование самого оператора «ПОИСКПОЗ» без кавычек. Затем сразу же открываем скобку и указываем координаты искомого значения. Это координаты той ячейки, в которую мы отдельно записали фамилию работника Парфенова. Ставим точку с запятой и указываем координаты просматриваемого диапазона. В нашем случае это адрес столбца с именами сотрудников. После этого закрываем скобку.

    После того, как все значения внесены, жмем на кнопку «OK».

  4. Окно аргументов функции ИНДЕКС в комбинации с оператором ПОИСКПОЗ в Microsoft Excel

  5. Результат количества заработка Парфенова Д. Ф. после обработки выводится в поле «Сумма».
  6. Результат обработки функции ИНДЕКС в комбинации с оператором ПОИСКПОЗ в Microsoft Excel

  7. Теперь, если в поле «Имя» мы изменим содержимое с «Парфенов Д.Ф.», на, например, «Попова М. Д.», то автоматически изменится и значение заработной платы в поле «Сумма».

Изменение значений при использовании функции ИНДЕКС в комбинации с оператором ПОИСКПОЗ в Microsoft Excel

Способ 3: обработка нескольких таблиц

Теперь посмотрим, как с помощью оператора ИНДЕКС можно обработать несколько таблиц. Для этих целей будет применяться дополнительный аргумент «Номер области».

Имеем три таблицы. В каждой таблице отображена заработная плата работников за отдельный месяц. Нашей задачей является узнать заработную плату (третий столбец) второго работника (вторая строка) за третий месяц (третья область).

  1. Выделяем ячейку, в которой будет производиться вывод результата и обычным способом открываем Мастер функций, но при выборе типа оператора выбираем ссылочный вид. Это нам нужно потому, что именно этот тип поддерживает работу с аргументом «Номер области».
  2. Выбор ссылочного вида функции ИНДЕКС в Microsoft Excel

  3. Открывается окно аргументов. В поле «Ссылка» нам нужно указать адреса всех трех диапазонов. Для этого устанавливаем курсор в поле и выделяем первый диапазон с зажатой левой кнопкой мыши. Затем ставим точку с запятой. Это очень важно, так как если вы сразу перейдете к выделению следующего массива, то его адрес просто заменит координаты предыдущего. Итак, после введения точки с запятой выделяем следующий диапазон. Затем опять ставим точку с запятой и выделяем последний массив. Все выражение, которое находится в поле «Ссылка» берем в скобки.

    В поле «Номер строки» указываем цифру «2», так как ищем вторую фамилию в списке.

    В поле «Номер столбца» указываем цифру «3», так как колонка с зарплатой является третьей по счету в каждой таблице.

    В поле «Номер области» ставим цифру «3», так как нам нужно найти данные в третьей таблице, в которой содержится информация о заработной плате за третий месяц.

    После того, как все данные введены, щелкаем по кнопке «OK».

  4. Окно аргументов функции ИНДЕКС при работе с тремя областями в Microsoft Excel

  5. После этого в предварительно выделенную ячейку выводятся результаты вычисления. Там отображается сумма заработной платы второго по счету работника (Сафронова В. М.) за третий месяц.

Результат обработки функции ИНДЕКС при работе с тремя областями в Microsoft Excel

Способ 4: вычисление суммы

Ссылочная форма не так часто применяется, как форма массива, но её можно использовать не только при работе с несколькими диапазонами, но и для других нужд. Например, её можно применять для расчета суммы в комбинации с оператором СУММ.

При сложении суммы СУММ имеет следующий синтаксис:

=СУММ(адрес_массива)

В нашем конкретном случае сумму заработка всех работников за месяц можно вычислить при помощи следующей формулы:

=СУММ(C4:C9)

Результат функции СУММ в Microsoft Excel

Но можно её немного модифицировать, использовав функцию ИНДЕКС. Тогда она будет иметь следующий вид:

=СУММ(C4:ИНДЕКС(C4:C9;6))

Результат комбинации функции СУММ и ИНДЕКС в Microsoft Excel

В этом случае в координатах начала массива указывается ячейка, с которой он начинается. А вот в координатах указания окончания массива используется оператор ИНДЕКС. В данном случае первый аргумент оператора ИНДЕКС указывает на диапазон, а второй – на последнюю его ячейку – шестую.

Урок: Полезные функции Excel

Как видим, функцию ИНДЕКС можно использовать в Экселе для решения довольно разноплановых задач. Хотя мы рассмотрели далеко не все возможные варианты её применения, а только самые востребованные. Существует два типа этой функции: ссылочный и для массивов. Наиболее эффективно её можно применять в комбинации с другими операторами. Созданные таким способом формулы смогут решать самые сложные задачи.

Понравилась статья? Поделить с друзьями:
  • Индекс столбца по значению в excel
  • Индекс столбца в excel это
  • Индекс сезонности формула excel
  • Индекс сезонности в excel в формуле
  • Индекс сводные таблицы excel