在使用公式時,我們經常遇到將某個值從結果數組中剔除,然后將該數組傳遞給另一個函數的情形。
例如,要獲取單元格區域中除0以外的最小值,可以使用數組公式:
=MIN(IF(A1:A10<>0,A1:A10))
或者對于Excel 2010及以后的版本,使用AGGREGATE函數:
=AGGREGATE(15,6,A1:A10/(A1:A10<>0),1)
(注意,這里必須指定第1個參數的值為15(SMALL),因為如果指定其值為5(MIN)的話,AGGREGATE函數不接受除實際的工作表單元格區域外的任何值。然而,如果指定該參數的值為14-19,那么可以先操作任何單元格區域,也可以使用來源于AGGREGATE函數里的其他函數生成的數組、或者常量數組,這些都不是指定其值為1-13所能夠處理的。)
然而,有時包含0的數組不是一個簡單的工作表單元格區域而是由函數通過計算生成的數組。在這種情形下,特別是公式相當長時,重復的子句將使公式更長,這使得公式看起來很“笨重”,并且還會使Excel進行一些不必要的計算,例如:
=MIN(IF([a_very_long_formula]<>0,[a_very_long_formula],””)
下面用一個例子來說明,如下所示:
在單元格H2中的公式為:
=MIN(SUMIFS(F2:F13,A2:A13,{“Mike”,”John”,”Alison”},B2:B13,”A”,C2:C13,”B”,D2:D13,”C”,E2:E13,”>=”&DATEVALUE(“2019/8/27”),E2:E13,”<=>=”&DATEVALUE(“2019/8/27”),E2:E13,”<=>=”&DATEVALUE(“2019/8/27”),E2:E13,”<=>=”&DATEVALUE(“2019/8/27”),E2:E13,”<=”& DATEVALUE(“2019/8/29″)))),””))
簡單解一下這個公式的運作原理。
根據上文得出的結果,上面的公式可以轉換為:
=MIN(IFERROR(1/(1/({5,0,4})),””))
轉換為:
=MIN(IFERROR(1/({0.2,#DIV/0!,0.25}),””))
轉換為:
=MIN(IFERROR({5,#DIV/0!,4},””))
可以看到,Excel將1/#DIV/0!的結果仍返回為#DIV/0!。轉換為:
=MIN({5,””,4})
結果為:
4
因此,可以使用這項技術來避免重復非常長的公式子句的情形。
也可以使用這項技術處理在公式中包含重復的單元格路徑引用的情形。例如:
=IF(VLOOKUP(A1,’C:\Documents andSettings\Long_Filepath_Name1\Long_Filepath_Name2\Long_Filepath_Name3\[External_Workbook_with_Ridiculously_Long_Name.xlsx]Sheet1′!$A$1:$B$10,2,0)=0,””,VLOOKUP(A1,’C:\DocumentsandSettings\Long_Filepath_Name1\Long_Filepath_Name2\Long_Filepath_Name3\[External_Workbook_with_Ridiculously_Long_Name.xlsx]Sheet1′!$A$1:$B$10,2,0))
可以使用下面的公式替代:
=IFERROR(1/(1/VLOOKUP(A1,’C:\Documents andSettings\Long_Filepath_Name1\Long_Filepath_Name2\Long_Filepath_Name3\[External_Workbook_with_Ridiculously_Long_Name.xlsx]Sheet1′!$A$1:$B$10,2,0)),””)
除了排除零以外,我們還可以在很多情形下使用此方法。我們需要做的就是操控想要排除值的公式,將其解析為0后再放置在IFERROR(1/(1/…后。例如,要獲取單元格A1:A10中除3以外的最小值,可以使用數組公式:
=MIN(IF(A1:A10<>3,A1:A10))
也可以使用公式:
=MIN(IFERROR(1/1/(A1:A10-3))+3,””))
還有一個示例:
=MIN(IFERROR(POWER(SQRT(A1:A10),2),””))
與下面的公式結果相同:
=MIN(IF(A1:A10>=0,A1:A10))
返回單元格A1:A10中除負數以外的值中的最小值。