[英]Append new records on the last empty row (instead of ignoring last empty rows and adding the new row at the end of the sheet)
[英]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.