INDIRECT函數返回由文本字符串指定的引用。
什么情況下使用INDIRECT函數?
INDIRECT函數返回由文本字符串指定的引用,可以用于:
創建開始部分固定的引用
創建對靜態命名區域的引用
從工作表、行、列信息創建引用
創建固定的數值組
INDIRECT函數語法
INDIRECT函數的語法如下:
INDIRECT(ref_text,a1)
ref_text是代表引用的文本字符串
如果a1為TRUE或者忽略,使用A1引用樣式;如果為FALSE,使用R1C1引用樣式
INDIRECT陷阱
INDIRECT函數是易失的,因此如果在許多公式中使用,那么它會使工作簿變慢。
如果INDIRECT函數創建對另一個工作簿的引用,那么該工作簿必須打開,否則公式的結果為#REF!錯誤。
如果INDIRECT函數創建所限制的行和列之外的區域的引用,那么公式將出現#REF!錯誤。(Excel 2007和Excel 2010)
INDIRECT函數不能對動態命名區域進行引用。
示例1:創建開始部分固定的引用
在第一個示例中,列C和列E有相同的數字,使用SUM函數求得的和也是相同的。然而,所使用的公式稍微有點不同。在單元格C8中,公式為:
=SUM(C2:C7)
在單元格E8中,INDIRECT函數創建對開始單元格E2的引用:
=SUM(INDIRECT(“E2”):E7)
如果在列表的頂部插入一行,例如輸入January的數量,列C中的和不會改變,但公式發生了變化,根據被插入的行進行了調整:
=SUM(C3:C8)
然而,INDIRECT函數鎖定開始單元格為E2,因此在E列的匯總單元格中會自動包括January的數量。結尾單元格改變了,但是開始單元格沒有受影響。
=SUM(INDIRECT(“E2”):E8)
示例2:創建對靜態命名區域的引用
INDIRECT函數也可以創建對命名區域的引用。在本例中,藍色單元格區域被命名為NumList,在列B中也有一個基于該列的數值數的動態區域。
通過在SUM函數中使用區域名稱,每個單元格都能夠計算總和,正如在單元格E3和E4中所看到的。
=SUM(NumList)或 =SUM(NumListDyn)
代替在SUM公式中輸入名稱,可以指向工作表單元格區域名稱。例如,使用在單元格D7中顯示的名稱NumList,單元格E7中的公式是:
=SUM(INDIRECT(D7))
不巧的是,INDIRECT函數不能夠解決對動態區域的引用,因此當公式向下復制到單元格E8中時,結果顯示#REF!錯誤。
示例3:從工作表、行、列信息創建引用
在INDIRECT函數中使用FALSE作為第二個參數容易創建基于行號和列號的引用。在本例中,創建R1C1樣式的引用,還包括了工作表名 — ‘MyLinks’!R2C2。
=INDIRECT(“’”& B3 & “’!R” & C3 & “C” & D3,FALSE)
示例4:創建固定的數值組
在一些公式中,需要一組數值,正如本例所示,我們想求列B中最大的3個數值的平均值。在公式中,可以輸入數值,如單元格D4中所示:
=AVERAGE(LARGE(B1:B8,{1,2,3}))
如果需要更多的一組數值,那么可能不想輸入這些數值。此時,可以使用ROW函數,如在單元格D5中使用的數組公式:
=AVERAGE(LARGE(B1:B8,ROW(1:3)))
還可以將ROW函數和INDIRECT函數聯合使用,也是數組公式:
=AVERAGE(LARGE(B1:B8,ROW(INDIRECT(“1:3”))))
上述3個公式的結果相同。
然而,如果在工作表的頂部插入行,第二個公式返回不正確的結果,因為行數被調整了。現在,顯示了第3、第4、第5個最大數值的平均值,而不是求最大的3個數值的平均值。
使用INDIRECT函數,第3個公式保持正確的行引用,并繼續顯示正確的結果。