FILTER 函數讓您根據自定義的準則來篩選資料範圍。
在下列範例中,我們使用公式 =FILTER (A5:D20,C5:C20=H2,“) 傳回 Apple 的所有記錄,如在單元格 H2 中選取,如果沒有 apples,則會傳回空字串 (”“) 。
FILTER 函數會根據布林 (真/假) 陣列來篩選陣列。
=FILTER(array,include,[if_empty])
引數 |
描述 |
array 必要 |
要篩選的陣列或範圍 |
include 必要 |
布林陣列的高度或寬度必須與該陣列相同 |
[if_empty] 選用 |
若所包含陣列中的全部值均為空時要傳回的值 (篩選沒有傳回任何項目) |
附註:
-
您可以將陣列想成是一列的值、一欄的值,或是一列值以及一欄值的組合。 在上例中,用於我們的 FILTER 公式的來源陣列是源自於範圍 A5:D20。
-
FILTER 函數將傳回一個陣列,若其為公式的最終結果則會溢出。 這表示,當您按 ENTER 時,Excel 將動態建立適當大小的陣列範圍。 如果支援資料是在 Excel 表格,而您使用了結構化參照,則您從陣列範圍新增或移除資料時,陣列會自動調整大小。 如需詳細資料,請參閱溢出陣列行為。
-
如果您的資料集可能傳回空值,請使用第 3 個引數 ([if_empty])。 否則,因為目前 Excel 不支援空陣列,這將導致 #CALC! error 。
-
如果 include 自變數的任何值為錯誤 (#N/A、#VALUE 等 ) 或無法轉換為布爾值,FILTER 函數會傳回錯誤。
-
Excel 對活頁簿之間的動態陣列提供有限支援,只有同時開啟活頁簿時才支援這種情況。 如果您關閉來源活頁簿,當您重新整理時,任何連結的動態陣列公式均會傳回 #REF! 錯誤 。
範例
FILTER 用於傳回多個準則
在此例中,我們使用乘號運算子 (*) 以傳回 (A5:D20) 陣列範圍中,擁有 Apples AND 且在 East 區域的所有值:=FILTER(A5:D20,(C5:C20=H1)*(A5:A20=H2),"")。
FILTER 用於傳回多個準則和排序
在此例中,我們使用之前的 FILTER 函數搭配 SORT 函數,以傳回 (A5:D20) 陣列範圍中,擁有 Apples AND 且在 East 區域的所有值,然後用遞減順序排序 Units:=SORT(FILTER(A5:D20,(C5:C20=H1)*(A5:A20=H2),""),4,-1)。
在此例中,我們使用 FILTER 函數搭配加號運算子 (+) 以傳回陣列範圍 (A5:D20) 中,擁有蘋果或在東部地區的所有值,然後按照遞減順序來排序單位:=SORT(FILTER(A5:D20,(C5:C20=H1)+(A5:A20=H2),""),4,-1)。
請注意,因為這些函數只存在於一個儲存格,且會將它們的結果溢出至鄰近儲存格,所以都不需要絕對參照。
需要更多協助嗎?
您可以隨時詢問 Excel 技術社群中的專家,或在社群中取得支援。