ฟังก์ชัน INDEX ส่งกลับค่าหรือการอ้างอิงไปยังค่าจากภายในตารางหรือช่วง

มีสองวิธีในการใช้ฟังก์ชัน INDEX:
-
ถ้าคุณต้องการส่งกลับค่าของเซลล์ที่ระบุหรืออาร์เรย์ของเซลล์ ให้ดูรูปแบบอาร์เรย์
-
ถ้าคุณต้องการส่งกลับการอ้างอิงไปยังเซลล์ที่ระบุ ให้ดูรูปแบบการอ้างอิง
รูปแบบอาร์เรย์
คำอธิบาย
ส่งกลับค่าขององค์ประกอบในตารางหรืออาร์เรย์ที่เลือกโดยดัชนีหมายเลขแถวและคอลัมน์
ให้ใช้รูปแบบที่เป็นอาร์เรย์ถ้าอาร์กิวเมนต์แรกไปยัง INDEX เป็นค่าคงที่อาร์เรย์
ไวยากรณ์
INDEX(array, row_num, [column_num])
รูปแบบอาร์เรย์ของฟังก์ชัน INDEX มีอาร์กิวเมนต์ดังนี้
-
array จำเป็น ช่วงของเซลล์หรือค่าคงที่อาร์เรย์
-
ถ้าอาร์เรย์มีเพียงหนึ่งแถวหรือหนึ่งคอลัมน์อาร์กิวเมนต์row_numหรืออาร์กิวเมนต์ column_numระบุหรือไม่ก็ได้
-
ถ้าอาร์เรย์มีมากกว่าหนึ่งแถวและมากกว่าหนึ่งคอลัมน์ และมีการใช้เฉพาะ row_num หรือ column_num ฟังก์ชัน INDEX จะส่งกลับอาร์เรย์ของทั้งแถวหรือทั้งคอลัมน์ในอาร์เรย์
-
-
row_num ต้องระบุ เว้นแต่column_numจะอยู่ เลือกแถวในอาร์เรย์ที่จะส่งกลับค่า ถ้าrow_numถูกละไว้ column_numให้ระบุ
-
column_num ไม่จำเป็น เลือกคอลัมน์ในอาร์เรย์ที่จะส่งกลับค่า ถ้าcolumn_numไม่ใส่ค่าrow_numคุณจะต้องใช้
ข้อสังเกต
-
ถ้ามีการใช้ทั้งrow_num column_numและอาร์กิวเมนต์แบบ column_numฟังก์ชัน INDEX จะส่งกลับค่าในเซลล์ที่จุดตัดของrow_numและcolumn_numทั้งสอง
-
row_num และ column_numต้องชี้ไปที่เซลล์ภายในอาร์เรย์ มิฉะนั้น INDEX จะ#REF! ข้อผิดพลาด
-
ถ้าคุณตั้งค่าrow_numค่าcolumn_numเป็น 0 (ศูนย์) ฟังก์ชัน INDEX จะส่งกลับอาร์เรย์ของค่าสําหรับทั้งคอลัมน์หรือทั้งแถวตามลําดับ เมื่อต้องการใช้ค่าที่ส่งกลับเป็นอาร์เรย์ ให้ใส่ฟังก์ชัน INDEX เป็นสูตรอาร์เรย์
หมายเหตุ: ถ้าคุณมีMicrosoft 365เวอร์ชันปัจจุบัน คุณสามารถใส่สูตรในเซลล์ด้านบนซ้ายของช่วงผลลัพธ์ แล้วกดENTERเพื่อยืนยันสูตรเป็นสูตรอาร์เรย์แบบไดนามิก มิฉะนั้น ต้องใส่สูตรเป็นสูตรอาร์เรย์ดั้งเดิม โดยการเลือกช่วงผลลัพธ์ ป้อนสูตรในเซลล์ด้านบนซ้ายของช่วงผลลัพธ์ แล้วกด CTRL + SHIFT + ENTER เพื่อยืนยัน Excel จะแทรกวงเล็บปีกกาที่จุดเริ่มต้นและจุดสิ้นสุดของสูตรให้คุณ สำหรับข้อมูลเพิ่มเติมเกี่ยวกับสูตรอาร์เรย์ ให้ดูที่ คำแนะนำและตัวอย่างของสูตรอาร์เรย์
ตัวอย่าง
ตัวอย่าง 1
ตัวอย่างเหล่านี้ใช้ฟังก์ชัน INDEX เพื่อค้นหาค่าในเซลล์ที่ตัดกันซึ่งแถวและคอลัมน์บรรจบกัน
คัดลอกข้อมูลตัวอย่างในตารางต่อไปนี้ และวางในเซลล์ A1 ของเวิร์กชีต Excel ใหม่ เพื่อให้สูตรแสดงผลลัพธ์ ให้เลือกสูตร กดF2แล้วกดEnter
ข้อมูล |
ข้อมูล |
|
---|---|---|
Apples |
Lemons |
|
Bananas |
Pears |
|
สูตร |
คำอธิบาย |
ผลลัพธ์ |
=INDEX(A2:B3,2,2) |
ค่าที่จุดตัดของแถวที่สองกับคอลัมน์ที่สองในช่วงเซลล์ A2:B3 |
Pears |
=INDEX(A2:B3,2,1) |
ค่าที่จุดตัดของแถวที่สองและคอลัมน์แรกในช่วงเซลล์ A2:B3 |
Bananas |
ตัวอย่าง 2
ตัวอย่างนี้ใช้ฟังก์ชัน INDEX ในสูตรอาร์เรย์เพื่อหาค่าในเซลล์สองเซลล์ที่ระบุในอาร์เรย์ 2x2
หมายเหตุ: ถ้าคุณมีMicrosoft 365เวอร์ชันปัจจุบัน คุณสามารถใส่สูตรในเซลล์ด้านบนซ้ายของช่วงผลลัพธ์ แล้วกดENTERเพื่อยืนยันสูตรเป็นสูตรอาร์เรย์แบบไดนามิก มิฉะนั้น ต้องใส่สูตรเป็นสูตรอาร์เรย์ดั้งเดิม โดยเลือกเซลล์ว่างสองเซลล์ ใส่สูตรในเซลล์ด้านบนซ้ายของช่วงผลลัพธ์ แล้วกด CTRL + SHIFT + ENTER เพื่อยืนยัน Excel จะแทรกวงเล็บปีกกาที่จุดเริ่มต้นและจุดสิ้นสุดของสูตรให้คุณ สำหรับข้อมูลเพิ่มเติมเกี่ยวกับสูตรอาร์เรย์ ให้ดูที่ คำแนะนำและตัวอย่างของสูตรอาร์เรย์
สูตร |
คำอธิบาย |
ผลลัพธ์ |
---|---|---|
=INDEX({1,2;3,4},0,2) |
ค่าที่พบในแถวแรก คอลัมน์ที่สองในอาร์เรย์ อาร์เรย์มี 1 และ 2 ในแถวแรกและ 3 และ 4 ในแถวที่สอง |
2 |
ค่าที่พบในแถวที่สอง คอลัมน์ที่สองในอาร์เรย์ (อาร์เรย์เดียวกันกับด้านบน) |
4 |
|
ฟอร์มการอ้างอิง
คำอธิบาย
ส่งกลับการอ้างอิงของเซลล์ที่จุดตัดของแถวและคอลัมน์ที่ระบุ ถ้าการอ้างอิงสร้างขึ้นจากส่วนที่เลือกที่ไม่อยู่ติดกัน คุณสามารถเลือกส่วนที่เลือกที่จะค้นหาได้
ไวยากรณ์
INDEX(reference, row_num, [column_num], [area_num])
รูปแบบการอ้างอิงของฟังก์ชัน INDEX มีอาร์กิวเมนต์ดังนี้
-
การอ้างอิง จำเป็น การอ้างอิงไปยังช่วงของเซลล์อย่างน้อยหนึ่งช่วง
-
ถ้าคุณใส่ช่วงที่ไม่ได้อยู่ติดกันเป็นการอ้างอิง ให้ใส่การอ้างอิงไว้ในวงเล็บ
-
ถ้าแต่ละพื้นที่ในการอ้างอิงมีเพียงหนึ่งแถวหรือหนึ่งคอลัมน์ อาร์กิวเมนต์ row_numหรือ column_num ตามลําดับ จะระบุหรือไม่ก็ได้ ตัวอย่างเช่น ใช้ INDEX(reference,,column_num) เพื่อการอ้างอิงแถวเดียว
-
-
row_num จำเป็น หมายเลขของแถวในการอ้างอิงที่จะส่งกลับการอ้างอิง
-
column_num ไม่จำเป็น จํานวนคอลัมน์ในการอ้างอิงที่จะส่งกลับการอ้างอิง
-
area_num ไม่จำเป็น เลือกช่วงในการอ้างอิงที่จะส่งกลับจุดตัดของrow_numและcolumn_num พื้นที่แรกที่เลือกหรือใส่เป็นหมายเลข 1 พื้นที่ที่สองเป็น 2 และอื่นๆ ถ้าarea_numถูกละไว้ INDEX จะใช้พื้นที่ 1 พื้นที่ทั้งหมดที่แสดงรายการอยู่ที่นี่ต้องอยู่ในแผ่นงานเดียว ถ้าคุณระบุพื้นที่ที่ไม่ได้อยู่ในแผ่นงานเดียวกันเหมือนพื้นที่อื่น จะทำให้เกิด #VALUE! เป็นข้อผิดพลาด ถ้าคุณต้องการใช้ช่วงที่อยู่ในแผ่นงานอื่น ขอแนะนำให้คุณใช้รูปแบบอาร์เรย์ของฟังก์ชัน INDEX และใช้ฟังก์ชันอื่นเพื่อคำนวณช่วงที่สร้างอาร์เรย์ขึ้น ตัวอย่างเช่น คุณสามารถใช้ฟังก์ชัน CHOOSE เพื่อคำนวณช่วงที่จะใช้ได้
ตัวอย่างเช่น ถ้าการอ้างอิงอธิบายเซลล์ (A1:B4,D1:E4,G1:H4) area_num 1 คือช่วง A1:B4, area_num 2 คือช่วง D1:E4 และ area_num 3 เป็นช่วง G1:H4
ข้อสังเกต
-
หลังจากการอ้างอิงarea_numที่เลือกช่วงใดช่วงหนึ่งแล้ว row_num และ column_num จะเลือกเซลล์ใดเซลล์หนึ่งโดยเฉพาะ row_num 1 เป็นแถวแรกในช่วง column_num 1 เป็นคอลัมน์แรก และอื่นๆ การอ้างอิงที่ส่งกลับโดย INDEX คือจุดตัดของrow_numและcolumn_num
-
ถ้าคุณตั้งค่าเป็น row_numหรือcolumn_numเป็น 0 (ศูนย์) ฟังก์ชัน INDEX จะส่งกลับการอ้างอิงสําหรับทั้งคอลัมน์หรือทั้งแถวตามลําดับ
-
row_num, column_num และ area_numต้องชี้ไปที่เซลล์ภายในการอ้างอิง มิฉะนั้น INDEX จะ#REF! ข้อผิดพลาด ถ้า row_num และ column_num ถูกละไว้ INDEX จะส่งกลับพื้นที่ในการอ้างอิงที่ระบุarea_num
-
ผลลัพธ์ของฟังก์ชัน INDEX เป็นการอ้างอิงและถูกแปลความหมายโดยสูตรอื่น ขึ้นอยู่กับสูตร ค่าที่ส่งกลับของ INDEX อาจถูกใช้เป็นการอ้างอิงหรือเป็นค่า ตัวอย่างเช่น สูตร CELL("width",INDEX(A1:B2,1,2)) จะเท่ากับ CELL("width",B1) ฟังก์ชัน CELL จะใช้ค่าที่ส่งกลับของ INDEX เป็นการอ้างอิงเซลล์ ในอีกทางหนึ่ง สูตร เช่น 2*INDEX(A1:B2,1,2) จะแปลค่าที่ส่งกลับของ INDEX เป็นตัวเลขในเซลล์ B1
ตัวอย่าง
คัดลอกข้อมูลตัวอย่างในตารางต่อไปนี้ และวางในเซลล์ A1 ของเวิร์กชีต Excel ใหม่ เพื่อให้สูตรแสดงผลลัพธ์ ให้เลือกสูตร กด F2 แล้วกด Enter
ผลไม้ |
ราคา |
นับจำนวน |
---|---|---|
Apples |
$0.69 |
40 |
Bananas |
$0.34 |
38 |
Lemons |
$0.55 |
15 |
Oranges |
$0.25 |
25 |
Pears |
$0.59 |
40 |
Almonds |
$2.80 |
10 |
Cashews |
$3.55 |
16 |
Peanuts |
$1.25 |
20 |
Walnuts |
$1.75 |
1.2 |
สูตร |
คำอธิบาย |
ผลลัพธ์ |
=INDEX(A2:C6, 2, 3) |
จุดตัดของแถวที่สองและคอลัมน์ที่สามในช่วงเซลล์ A2:C6 ซึ่งเป็นเนื้อหาในเซลล์ C3 |
38 |
=INDEX((A1:C6, A8:C11), 2, 2, 2) |
จุดตัดของแถวที่สองและคอลัมน์ที่สองในพื้นที่ที่สองของ A8:C11 ซึ่งเป็นเนื้อหาในเซลล์ B9 |
1.25 |
=SUM(INDEX(A1:C11, 0, 3, 1)) |
ผลบวกของคอลัมน์ที่สามในพื้นที่แรกของช่วงเซลล์ A1:C11 ซึ่งเป็นผลบวกของช่วงเซลล์ C1:C11 |
216 |
=SUM(B2:INDEX(A2:C6, 5, 2)) |
ผลบวกของช่วงเซลล์ที่เริ่มต้นจาก B2 และสิ้นสุดที่จุดตัดของแถวที่ห้ากับคอลัมน์ที่สองของช่วงเซลล์ A2:A6 ซึ่งเป็นผลบวกของช่วงเซลล์ B2:B6 |
2.42 |