во-первых, вы должны изменить это SUMPRODUCT
формула. Он не требует, чтобы вы вводили его как формулу массива и - IMHO - его проще использовать.
=SUMPRODUCT(M16:M977*(MOD(ROW(M16:M977)-ROW(M16),4)=0))
чтобы обойти поведение Excel при вставке строк, я рекомендую превратить ваши данные в таблицу. (Вставить ленту > таблица) это делает ссылку "Все данные в этой области" очень легко, и он обновляет так, как вы хотите, когда таблица становится больше или меньше. В этом случае формула будет выглядеть что-то вроде этого:
=SUMPRODUCT(Table1[Hours]*(MOD(ROW(Table1[Hours])-ROW(Table1[[#Headers],[Hours]])-1,4)=0))
если по какой-то причине вы не можете превратить его в таблицу, я бы рекомендовал создать именованный диапазон и ссылаться на него. Формула для названного диапазона будет:
=OFFSET(Sheet3!$M,15,0,MATCH(9E+99,Sheet3!$M:$M)-15)
... и Формула, ссылающаяся на это, будет:
=SUMPRODUCT(rngHours*(MOD(ROW(rngHours)-ROW(OFFSET(rngHours,0,0,1,1)),4)=0))
... где rngHours
- это то имя, которое вы дали именованному диапазону.
если вы действительно не хотите использовать именованные диапазоны, вы можете хлюпать все в одну большую формулу, но это будет грязно, хотя и функция:
=SUMPRODUCT(OFFSET(Sheet3!$M,15,0,MATCH(9E+99,Sheet3!$M:$M)-15)*(MOD(ROW(OFFSET(Sheet3!$M,15,0,MATCH(9E+99,Sheet3!$M:$M)-15))-ROW(OFFSET(Sheet3!$M,15,0)),4)=0))