MATCH 函數

套用到
Microsoft 365 Excel Mac 版 Microsoft 365 Excel Excel 2024 Mac 版 Excel 2024 Excel 2021 Mac 版 Excel 2021 Excel 2019 Excel 2016

秘訣

試試看新的 XMATCH 函數,這是 MATCH 的改良版,可以任意方向運作,預設會回傳精確匹配,比前代更簡單方便。

MATCH 函數會搜尋儲存格範圍中的指定項目,並傳回該項目於該範圍中的相對位置。 例如,若範圍 A1:A3 中含有值 5、25 及 38,則公式 =MATCH(25,A1:A3,0) 會傳回數字 2,因為 25 是範圍中的第二個項目。

秘訣

當您需要的是項目在範圍內的位置而不是項目本身,請使用 MATCH 函數,而不要使用其中一個 LOOKUP 函數。 例如,你可以用 MATCH 函數來提供 INDEX 函數的 row_num 參數值。

語法

MATCH(lookup_value, lookup_array, [match_type])

MATCH 函數語法具有下列引數:

  • lookup_value 必須。 你想要在 lookup_array中匹配的價值。 例如,當您在通訊錄中查閱某個人的號碼時,您是以那個人的姓名作為查閱值,但是電話號碼才是您要的值。

    lookup_value 引數可以是一值 (數字、文字或邏輯值),也可以是數字、文字或邏輯值的儲存格參照。

  • lookup_array 必須。 這是要搜尋的儲存格範圍。

  • match_type 可選的。 數字 -1、0 或 1。 match_type 參數指定 Excel 如何將lookup_valuelookup_array 的數值匹配。 這個引數的預設值是 1。

    下表將描述該函數如何根據 match_type 引數的設定來尋找值。

Match_type 行為
1 或省略 MATCH 會找到小於或等於 lookup_value 的最大值。 lookup_array 參數中的值必須依序排列,例如:...-2, -1, 0, 1, 2, ..., A-Z, FALSE, TRUE。
0 MATCH 會找到第一個完全等於 lookup_value 的值。 lookup_array 參數中的值可以是任意順序。
-1 MATCH 會找到大於或等於lookup_value 的最小值。 lookup_array 參數中的值必須依降序排列,例如:TRUE、FALSE、Z-A、...2、1、0、-1、-2、...,依此類推。
  • MATCH 回傳 lookup_array中匹配值的位置,而非該值本身。 例如, MATCH (“b”,{“a”,“b”,“c”},0) 回傳 2,即 “b” 在陣列 {“a”, “b”, “c”} 中的相對位置。
  • MATCH 函數在比較文字值時,字母不會區分大小寫。
  • 如果 MATCH 函數無法找到符合的項目,則傳回 #N/A 錯誤值。
  • 如果 match_type0,lookup_value 是文字串,你可以在lookup_value論點中使用萬用字元——問號 (?) 和星號 () * 。 問號可比對任一字元;星號可比對任一連續的字元。 如果你想找真正的問號或星號,請在字元前輸入波浪 (~)

範例

請在下列表格中複製範例資料,再將之貼到新 Excel 活頁簿中的儲存格 A1。 若要讓公式顯示結果,請選取公式,按 F2,然後再按 Enter。 如有需要,您可以調整欄寬來查看所有資料。

產品 項目個數
香蕉 25
柑橘 38
蘋果 40
梨子 41
公式 描述 結果
=MATCH(39,B2:B5,1) 因為沒有完全符合的項目,所以會傳回範圍 B2:B5 中下一個最小值 (38) 的位置。 2
=MATCH(41,B2:B5,0) 範圍 B2:B5 中,值為 41 的位置。 4
=MATCH(40,B2:B5,-1) 因為範圍 B2:B5 內的值不是依遞減順序排列,所以會傳回錯誤。 #N/A