繁体   English   中英

获取行之间的最大变化,忽略列表末尾的空单元格

[英]Get max change between rows, ignoring empty cells at end of list

我有一个电子表格,我在其中跟踪我的净资产随着时间的推移。 每月一次,我添加我的帐户余额。

在一张纸上,我有这样的结构:

日期 净值 帐户1 账户2 帐户3
2021 年 1 月 31 日 2021 320 美元 200 美元 140 美元 -$20
2021 年 2 月 28 日 2021 340 美元 200 美元 150 美元 -$10
2021 年 3 月 31 日 2021 410 美元 250 美元 200 美元 -$40
2021 年 4 月 30 日
2021 年 5 月 31 日

...rest 月份的一年

Year 列中的公式为=if(C3<>"", year(A3), "")

净值列中的公式是=if(sum(D3:F3)<>0, sum(D3:F3), "")

问题:我想要一个列出 1 个月最大变化的单元格(因此 $410 - $340 = $70),而不必每个月更新公式。 (在一个理想的世界里,我永远不需要再碰它,只需要每月输入一次账户余额。)

到目前为止我得到了什么:

=if(
  abs(min(ArrayFormula(C3:C400 - C2:C399)))=max(ArrayFormula(abs(C3:C400 - C2:C399))), 
  min(ArrayFormula(C3:C400 - C2:C399)),
  max(ArrayFormula(C3:C400 - C2:C399))
)

但是,这包括从 $410 到""的更改,这被强制更改为 $0。 因此,我得到的不是预期的 70 美元,而是 410 美元。

如何获得最大的 1 个月变化,但忽略空字符串值?

解决它的最简单方法就是放入我认为的 if 子句:

=ArrayFormula(max(if(C3:C400<>"",abs(C3:C400-C2:C399),)))

因为 Max 会忽略 If 语句生成的空字符串

或略短:

=ArrayFormula(max((C3:C400<>"")*abs(C3:C400-C2:C399)))

以便将任何空单元格的更改设置为零。

这些假设 C2 本身不是空白的!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM