Page 1 of 1
Fix การคีย์
Posted: Wed Feb 08, 2012 3:28 pm
by adodc
ถ้าต้องการ Fix ในการกรอกข้อมูล
เช่น ถ้า Column A = 1 ให้ Column B กรอกได้เฉพาะตัวเลขและตัวอักษณ ก ข ค โดยที่กรอกจำนวนเท่าไรก็ได้
แล้วถ้่า Column A = 2 ให้ Column B กรอกได้เฉพาะตัวเลข
แล้วถ้่า Column A = 3 ให้ Column B ไม่สามรถกรอกข้อมูลได้เลย
ขอบคุณค่ะ
Re: Fix การคีย์
Posted: Wed Feb 08, 2012 4:49 pm
by snasui

ลองตามนี้ครับ
- เซลล์ A1 เป็นเซลล์ที่ต้องการให้เลือกตัวเลข 1 หรือ 2 หรือ 3
- เซลล์ B1 คือเซลล์ที่ต้องการให้คีย์ข้อมูล
- เซลล์ C1 คือสูตรเพื่อเช็คว่าตรงตามเงื่อนไขหรือไม่โดยคีย์สูตร
=OR(AND(A1=1,OR(COUNT(MATCH(MID(B1,ROW(INDIRECT("1:"&LEN(B1))),1),{0,1,2,3,4,5,6,7,8,9,"ก","ข","ค"},0))=LEN(B1))),AND(A1=2,ISNUMBER(B1+0)),AND(A1=3,LEN(B1)=0))
กดแป้น Ctrl+Shift+Enter แทนการกดแป้น Enter เพื่อรับสูตร
- คลิกเซลล์ B1 แล้วเข้าเมนู Data > Validation
- ช่อง Allow เลือก Custom
- ช่อง Formula: คีย์สูตร =C1
- ทดสอบกรอกค่าในเซลล์ B1 แล้วสังเกตดูผล
Re: Fix การคีย์
Posted: Thu Feb 09, 2012 9:34 am
by adodc
มันได้ค่า 2 และ 3
ค่า 1 จะขึ้น Error มาให้ค่ะ
อยากให้มันคีย์ใน Column B ไม่ได้เลย ถ้าไม่ตรงตามเงื่อนไข
Column A เป็น Column ที่มีข้อมูลอยู่แล้วไม่ต้องเลือก
Column B เป็น Column ที่ต้องกรอกข้อมูลลงไป
1.Column A1 = 1 ให้ Column B1 กรอกได้เฉพาะตัวเลขและตัวอักษร ก ข ค (แค่สามตัวนี้)
โดยที่จะกรอกตัวเลขอย่างเดียว , ก ข ค อย่างเดียวหรือตัวใดตัวหนึ่ง ,หรือผสมทั้ง 2 อย่าง ซึ่งทั้งตัวเลขและตัวอักษรจะกรอกซ้ำกันก็ได้
2.Column A1 = 2 ให้ Column B1 กรอกได้เฉพาะตัวเลขเท่านั้น
3.Column A1 = 3 ให้ Column B1 กรอกได้ทุกอย่างเลย
มีปัญหาใน Excel 2007 นะค่ะ
หัว Column มันไม่เป็น A B C มันเป็นตัวเลข 1 2 3 แทน ต้องไปเซตครงไหนค่ะ
Re: Fix การคีย์
Posted: Thu Feb 09, 2012 2:29 pm
by snasui

อย่างแรกต้องเข้าใจก่อนนะครับว่าที่ผมทำแนะนำนั้นเป็นแค่ตัวอย่าง ไม่ได้หมายความว่าคีย์แค่เซลล์เดียวคือ C1 แล้วจะมีผลกับทุกเซลล์ในคอลัมน์ A:B
กรณีนำไปใช้งานจริงให้ Copy B1 และ C1 ลงด้านล่างควบคู่กันกับข้อมูลในคอลัมน์ A ครับ และเราสามารถซ่อนคอลัมน์ C เอาไว้ก็ย่อมได้
ส่วนการแสดงหัวคอลัมน์เป็นตัวอักษรให้คลิก Office Button (ปุ่มกลม ๆ ด้านซ้ายมือบน) > Excel Options แล้วปลดเครื่องหมายที่ R1C1 reference style ตามภาพด้านล่างครับ