Подтвердить что ты не робот

Фильтрация массива с использованием формулы (без VBA)

Можно ли фильтровать массив с использованием одной формулы (без автофильтра, VBA или дополнительных столбцов)?

Например, у меня есть следующая таблица:

   A  | B     | C
 --------------------
1| ID | Class | Value
2| 1  | A     | V1
3| 1  | B     | V2
4| 2  | A     | V3
5| 3  | B     | V4
6| 3  | B     | V5

Я хочу использовать подмножество этого массива в VLOOKUP. А именно, я хочу только совпадение с теми строками, где класс "B". Поэтому я надеялся, что смогу использовать что-то вроде следующего

=VLOOKUP(A3, FILTER_FUNC(A:C, B="B"), 3, false)

где FILTER_FUNC - это некоторый тип функции или выражения, который возвращает массив, который содержит только те строки, которые соответствуют условию.

4b9b3361

Ответ 1

=VLOOKUP(A2,IF(B1:B3="B",A1:C3,""),1,FALSE)

Ctrl+Shift+Enter для ввода.

Ответ 2

Это сделает это, если вы хотите только первое значение "B", вы можете добавить адрес ячейки для "B", если хотите сделать его более общим.

=INDEX(A2:A6,SUMPRODUCT(MATCH(TRUE,(B2:B6)="B",0)),1)

Чтобы использовать это на основе двух столбцов, просто конкатенируйте внутри матча:

=INDEX(A2:A6,SUMPRODUCT(MATCH(TRUE,(A2:A6&B2:B6)=("3"&"B"),0)),1)

Ответ 3

Похоже, вы просто пытаетесь сделать классический двухколоночный поиск. http://www.dailydoseofexcel.com/archives/2009/04/21/vlookup-on-two-columns/

Тонны решений для этого, наиболее простые, вероятно, следующие (что не требует формулы массива):

=SUMPRODUCT((Lookup!A:A=Param!A1)*(Lookup!B:B=Param!B1)*(Lookup!C:C))

Чтобы перевести ваш конкретный пример, вы должны использовать:

=SUMPRODUCT((A1:A3=A2)*(B1:B3="B")*(C1:C3))