1

我在 googlesheet 中有数据,我需要连续查找最后 6 个值的平均值。每周我都会添加另一个数据点,因此我需要它来计算滚动平均值。我尝试使用以下公式来计算它:

=iferror(average(offset(CT3,0,max(0,count(CT3:DM3)-6),1,6)),0)

当我使用低于平均值的数据集进行此操作时,平均值计算为 7。但实际平均值应为 7.67。任何人都可以帮忙吗?

表格中的数据如下:

ARI 16 0 18 5 8 12 11 1 12 3 8 - 11 - - - - - - -
4

2 回答 2

0

尝试:

=INDEX(AVERAGE(ARRAY_CONSTRAIN(SORT(INDIRECT("A1:"&
  ADDRESS(MAX(ISNUMBER(A:A)*ROW(A:A)), 1, )),
 SEQUENCE(MAX(ISNUMBER(A:A)*ROW(A:A))), 0), 7, 1)))

在这里输入代码


更新:

=INDEX(AVERAGE(ARRAY_CONSTRAIN(SORT(FLATTEN(INDIRECT("A1:"&
 ADDRESS(1, MAX(ISNUMBER(1:1)*COLUMN(1:1))))), 
   SEQUENCE(MAX(ISNUMBER(1:1)*COLUMN(1:1))), 0), 7, 1)))

在此处输入图像描述

于 2021-12-08T21:51:22.807 回答
0

我想知道是否有一种方法可以在不排序的情况下做到这一点。对于评论中的示例:

=(sum(E3:X3)-sum(array_constrain(filter(E3:X3,isnumber(E3:X3)),1,count(E3:X3)-4)))/4

在此处输入图像描述

于 2021-12-09T13:05:32.563 回答