การแสดงข้อมูล จากวิธีเลือก Drop Down Filte
รูปที่ 1 ตารางข้อมูลที่ต้องการให้แสดงข้อมูลตาม DropDownList |
จากรูปที่ 1 เป็นตารางข้อมูลเดิม ที่เราจะมากำหนดให้แสดงข้อมูลตาม DropDownList ซึ่งคุณๆ
ต้องเพิ่มคอลัมน์ที่ 1 เพื่อเป็นคอลัมน์แสดงลำดับที่ คอลัมน์ที่ 2 เพื่อเป็นคอลัมน์ที่แสดงข้อมูลตาม DropDownList และ คอลัมน์ที่ 3 เพื่อแสดงตัวเลขทั้งหมดในคอลัมน์ที่ 2
ต้องสร้างตารางที่จะใช้เป็นเงื่อนไขให้กับ Drop Down List ดังรูปที่ 2
รูปที่ 2 ตารางที่เพิ่ม Column 1-3 และสร้าง DropDownList |
1. สร้าง List ที่ไม่มีข้อมูลซ้ำกัน เพื่อนำข้อมูลใน List ไปสร้าง DropDownList อีกที
1.1. คัดลอกข้อมูลในคอลัมน์ Module มาวางไว้ในส่วนอื่นของ Worksheet ตามรูปที่ 2 วางไว้ที่คอลัมน์ G
1.2. เลือกเมนู Data >> Remove Duplicates โปรแกรม Excel จะตัดข้อความที่ซ้ำกันทิ้งไป ซึ่งเราจะนำข้อมูลนี้ มาสร้าง Drop down list กัน
2. การสร้าง Drop down list คุณสามารถกลับไปทบทวนการสร้าง ตามตัวอย่างที่ 1 ในบทความ "การสร้าง Drop Down List ทั้งแบบง่ายๆ และแบบมีเงื่อนไข" นี้
3. สร้างคอลัมน์อีก 2 คอลัมน์ โดย
3.1. คอลัมน์ที่ 1 ให้แสดงเลข runing number
3.2. คอลัมน์ที่ 2 ให้เขียนสูตรฟังก์ชั่น =IF(A2=$I$1,D2,"") ในเซลล์ E2 ซึ่งฟังก์ชั่นนี้ จะทำการตรวจสอบเซลล์ E2 ว่ามีข้อมูล A2 มีค่าเท่ากับคอลัมน์ I1 หรือไม่ ถ้ามีค่าเท่ากันให้แสดงข้อมูลเหมือนเซลล์ D2 แต่ถ้าไม่เหมือนกันก็แสดงค่าว่าง
3.3. คอลัมที่ 3 ให้นำเลขในคอลัมน์ที่ 2 มาแสดง โดยเขียนสูตรฟังก์ชั่น =IFERROR(SMALL($E$2:$E$27,$D2),"") ในเซลล์ F2 ซึ่งฟังก์ชั่นนี้ SMALL จะทำการตรวจสอบค่าในเซลล์ D2 ภายในช่วง E2 ถึง E27 ถ้าในเซลล์ D2 มีค่าให้แสดงตัวเลข แต่ถ้าค่าไม่ตรงกัน ฟังก์ชันจะคืนค่า #NUM! ซึ่งถ้าเราเขียนเฉพาะฟังก์ชั่น SMALL เพียงฟังก์ชั่นเดียว ตารางเราคงจะดูไม่ดีเท่าไร ดังนั้น เราจะเอาฟังก์ชั่น IFERROR มาควบคุม เมื่อเจอ Error ต่างๆ เราจะให้แสดงเป็นค่าว่าง ดังรูปที่ 2
4. ขั้นตอนสุดท้าย คือ การเขียนสูตรทีละคอลัมน์
=IFERROR(INDEX($A$2:$A$27,$F2,COLUMNS($J$2:$J$27)),"")
=IFERROR(INDEX($B$2:$B$27,$F2,COLUMNS($K$2:$K$27)),"")
=IFERROR(INDEX($C$2:$C$27,$F2,COLUMNS($L$2:$L$27)),"")
เพื่อสร้างตารางที่เปลี่ยนข้อมูลตามที่เลือก DropDownList ดังรูปที่ 3
รูปที่ 3 แสดงตารางที่เขียนจากสูตร เพื่อให้แสดงข้อมูลที่เปลี่ยนไปตาม DropDownList |