Page 1 of 1

การตั้งรหัสของรายการปัญหาไม่ให้ตัวเลขซ้ำกัน

Posted: Tue Sep 14, 2010 8:01 pm
by godman
คืออยากให้มันตังระหัสของ colump D โดยไม่ให้รหัสซ้ำกัน
ลองมา 2 ชั่วโมงแล้วไม่ได้ครับ
จะตั้งสูตรใน colump C อย่างไรดีครับใช้คอลัมพ์ A เป็นตัวตั้งครับ เช่น SUS.1.1
SUS.1.2 SUS.2.1

Re: การตั้งรหัสของรายการปัญหาไม่ให้ตัวเลขซ้ำกัน

Posted: Tue Sep 14, 2010 9:51 pm
by snasui
:shock: ลองตามนี้ครับ

ที่ C2 คีย์

=A2&"."&MAX(B$2:B2)&"."&ROWS(OFFSET($B$2,MATCH(9.99999999999999E+307,B$2:B2),0):OFFSET($B$2,MATCH(MAX($B$2:B2),$B$2:B2,0),0))

Enter > Copy ลงด้านล่าง ดูไฟล์แนบประกอบครับ :mrgreen:

Re: การตั้งรหัสของรายการปัญหาไม่ให้ตัวเลขซ้ำกัน

Posted: Tue Sep 14, 2010 10:03 pm
by godman
คือในคอลัมพ์ D ว่างก็ให้มันว่างด้วยหละครับ สูตรยาวมากเลยนะเครับ ผมใช้ if ไป if มาจนพรุน
VEM 0 VEM.6.147
Cle n/a VEM.6.147 n/a
คือ ตรงนี้อะครับยังไม่เข้าเงือนไขครับ เพราะว่ามันควรจะเป็น Cle.n/a. อะไครับ คือให้มันดูที่ คอลัมพ์ D ครับถ้าไม่มีก็ไม่ให้มันแสดงอะไร

Re: การตั้งรหัสของรายการปัญหาไม่ให้ตัวเลขซ้ำกัน

Posted: Tue Sep 14, 2010 10:10 pm
by snasui
:D ลองยกตัวอย่างมาให้เห็นภาพหน่อยครับ ส่งตัวอย่างมาใหม่ ทำเป็นตัวอย่างมาก็พอครับ ถ้ามี n/a ต้องการให้แสดงค่าอย่างไร ช่วยกรอกค่าที่ถูกต้องมาเป็นตัวอย่างให้ด้วยเช่นที่ทำมาจะดีมากครับ :mrgreen:

Re: การตั้งรหัสของรายการปัญหาไม่ให้ตัวเลขซ้ำกัน

Posted: Tue Sep 14, 2010 10:21 pm
by godman
ถ้าคอลัมพ D ไม่มีหรือที่เป็น n/a ก็ไม่ให้แสดงค่าอะไรครับ
ผมแนบตัวอย่างมาใหม่ครัลบ

Re: การตั้งรหัสของรายการปัญหาไม่ให้ตัวเลขซ้ำกัน

Posted: Wed Sep 15, 2010 12:01 am
by snasui
:D ลองตามนี้ครับ

C1 คีย์

=IF(OR(D2="",D2="n/a"),"",A2&"."&LOOKUP(2,1/(B$2:B2),B$2:B2)&"."&ROWS(OFFSET($B$2,MATCH(2,1/(B$1:B2))-2,0):OFFSET($B$2,MATCH(9.99999999999999E+307,$B$2:B2)-1,0)))

Ctrl+Shift+Enter > Copy ลงด้านล่าง ลองดูตามไฟล์แนบครับ

Re: การตั้งรหัสของรายการปัญหาไม่ให้ตัวเลขซ้ำกัน

Posted: Wed Sep 15, 2010 7:37 am
by godman
ตรงตามความต้องการครับ ขอบพระคุณเป็นอย่างสูงครับ ผมนึกไม่ถึงจริงๆว่าปัญหานึกว่าจะง่าย แค่สูตร if อย่างเดียวก็น่าจะเอาอยู่ แต่ที่ใหนได้ซับซ้อนมากมายเลยจริงๆผมก็อยากจะได้คำอะิบายสูตรด้วย แต่รบกวนอาจารย์มากมายแล้ว เมื่อคืนก็อยู่ดึกมากเลยนะครับ ขอบคุณครับ

Re: การตั้งรหัสของรายการปัญหาไม่ให้ตัวเลขซ้ำกัน

Posted: Wed Sep 15, 2010 5:26 pm
by snasui
:D สำหรับคำอธิบายสูตรดูตามด้านล่างครับ

ขออธิบายสูตรในเซลล์ C4 แล้วกันครับ

=IF(OR(D4="",D4="n/a"),"",A4&"."&LOOKUP(2,1/(B$2:B4),B$2:B4)&"."&ROWS(OFFSET($B$2,MATCH(2,1/(B$1:B4))-2,0):OFFSET($B$2,MATCH(9.99999999999999E+307,$B$2:B4)-1,0)))

หลักการคือการเชื่อมข้อมูลเข้าด้วยกัน โดยนำ 3 ค่าตามด้านล่างมาเชื่อมเข้าด้วยกัน
  1. IF(OR(D4="",D4="n/a"),"",A4&"."&LOOKUP(2,1/(B$2:B4),B$2:B4)
  2. "." และ
  3. ROWS(OFFSET($B$2,MATCH(2,1/(B$1:B4))-2,0):OFFSET($B$2,MATCH(9.99999999999999E+307,$B$2:B4)-1,0))

คำอธิบายสูตร

ข้อ 1 หมายความว่า หาก D4 เป็นค่าว่าง หรือมีค่าเป็น n/a ก็ให้แสดงค่าว่าง หากไม่เข้าเงื่อนไขข้างต้นก็ให้แสดงผลลัพธ์จากสูตร A4&"."&LOOKUP(2,1/(B$2:B4),B$2:B4) ซึ่ง LOOKUP(2,1/(B$2:B4),B$2:B4) เป็นการหาค่าตัวเลขสุดท้ายที่ไม่ใช่ 0 ที่พบในช่วง B$2:B4

ข้อ 2 เครื่องหมายจุด

ข้อ 3 เป็นการหาระยะห่างระหว่าง OFFSET($B$2,MATCH(2,1/(B$1:B4))-2,0) กับ OFFSET($B$2,MATCH(9.99999999999999E+307,$B$2:B4)-1,0)
  1. OFFSET($B$2,MATCH(2,1/(B$1:B4))-2,0) หมายถึง ตำแหน่งเซลล์สุดท้ายที่ไม่ใช่ 0 ในช่วง B1:B4
  2. OFFSET($B$2,MATCH(9.99999999999999E+307,$B$2:B4)-1,0) หมายถึงตำแหน่งเซลล์สุดท้ายในช่วง B2:B4 ที่เป็นตัวเลขรวมทั้ง 0
  3. ROWS(OFFSET($B$2,MATCH(2,1/(B$1:B4))-2,0):OFFSET($B$2,MATCH(9.99999999999999E+307,$B$2:B4)-1,0)) คือระยะห่างระหว่างเซลล์สุดท้ายที่เป็นตัวเลขที่ไม่ใช่ 0 กับเซลล์สุดท้ายที่เป็นตัวเลข

Re: การตั้งรหัสของรายการปัญหาไม่ให้ตัวเลขซ้ำกัน

Posted: Wed Sep 15, 2010 10:27 pm
by godman
อื้อ ครับ คงไม่แกะแล้วหละครับ