我使用下面的函数

=DAYS360(A2, A35)

计算我列中两个日期的差值。然而,列一直在扩大,我目前必须手动更改“A35”,因为我更新了我的电子表格。

是否有一种方法(在谷歌表)找到该列中的最后一个非空单元格,然后在上面的函数中动态设置该参数?


当前回答

我最喜欢:

=INDEX(A2:A,COUNTA(A2:A),1)

所以,对于OP的需求:

=DAYS360(A2,INDEX(A2:A,COUNTA(A2:A),1))

其他回答

如果A2:A包含连续的日期,则INDEX(A2:A,COUNT(A2:A))将返回最后一个日期。最后的公式是

=DAYS360(A2,INDEX(A2:A,COUNT(A2:A)))

为了找到最后一个非空行号(允许行号之间有空格),我使用下面的方法搜索列A。

=ArrayFormula(IFNA(match(2,1/(A:A<>""))))

通过LAMBDA和REDUCE函数的引入,我们现在可以在一次遍历单元格中计算行号(上面的几个解决方案过滤了两次范围),而不依赖于神奇的文本或数值。

=lambda(rng, 
   REDUCE(0, rng, lambda(maxrow, cell, if(isblank(cell),maxrow,row(cell)) ) )
)(A:A)

它可以很好地打包成一个命名函数的用法,如

=LAST_ROWNUM(A:A)

它适用于具有穿插空格的列、多列范围(因为REDUCE在行优先的范围内迭代)和部分列(如A20:A),仍然返回实际的行号(而不是范围内的偏移量)。

然后可以将其与Index组合以返回值

=DAYS360(A2, Index(A1, LAST_ROWNUM(A:A)))

(事实上,我怀疑OPs日期值是单调的(即使中间有空格),他可以侥幸逃脱

=DAYS360(A2, MAX(A2:A))

上面的解决方案是依赖于“连续”的日期——这是否意味着“没有空白”或“没有缺失日期”我不确定——但这两种规定都是不必要的。)

这对我很有用。获取谷歌表中A列的最后一个值:

=index(A:A,max(row(A:A)*(A:A<>"")))

(如果有空白行,它也会跳过空白行)

那么下面这个求最后一个值的公式呢:

=index(G:G;max((G:G<>"")*row(G:G)))

这就是你最初任务的最终公式:

=DAYS360(G10;index(G:G;max((G:G<>"")*row(G:G))))

假设您的初始日期是G10。