秘訣
試試看新的 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_value與 lookup_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_type 為 0,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 |