Ваша формула не работает, поскольку [Rule operator]
является диапазоном, поэтому, если ваша формула введена в ячейку в строке 5, Excel оценит вашу формулу следующим образом:
=MATCH("THEN",[@[Rule operator]]:[Rule operator],0)
↓↓↓
=MATCH("THEN",$A$5:$A$2:$A$12,0)
Поскольку A5 находится в середине диапазона A2:A12, Excel игнорирует его и просто использует A2:A12.
Для решения этой проблемы вы можете оставить бит [@[Rule operator]]
но вам нужно что-то выяснить, где находится последняя ячейка в вашем столбце.
Вы можете сделать это, посчитав количество строк в вашей таблице, используя ROWS([Rule operator])
, добавив 1 для строки заголовка (добавьте больше, если у вас есть другие строки над таблицей), затем используя функцию INDIRECT
чтобы собрать это в ссылка на ячейку. Это дает вам:
=MATCH("THEN",[@[Rule operator]]:INDIRECT("A"&1+ROWS([Rule operator])),0)
Поскольку при этом будет выведена позиция строки MATCH
включая строку, из которой вы запускаете формулу, вам необходимо вычесть 1, чтобы вычислить значение смещения THEN , необходимое для каждой строки:
=MATCH("THEN",[@[Rule operator]]:INDIRECT("A"&1+ROWS([Rule operator])),0)-1
Это оно :)