:D snasui.com ยินดีต้อนรับ :D
ยินดีต้อนรับสู่กระดานถามตอบ Excel and VBA และอื่น ๆ ที่เป็นมิตรกับทุกท่าน มีไฟล์แนบมหาศาล ช่วยให้ท่านค้นหาและติดตามศึกษาได้โดยง่าย :thup: สมาชิกท่านใดที่ยังไม่ได้ระบุ Version ของ Excel ที่ใช้งานจริง สามารถทำตาม Link นี้เพื่อจะได้รับคำตอบที่ตรงกับ Version ของท่านครับ :arrow: ระบุ Version ของ Excel
:!: โปรดทราบ :!:
  1. กรุณาอ่านกฎการใช้บอร์ด (Forum rules) ในตำแหน่งด้านบนของแต่ละบอร์ด
  2. การสมัครสมาชิก การ Login การกู้คืนรหัสผ่าน
    1. สมัครสมาชิกดูขั้นตอนได้ที่ :arrow: สมัครสมาชิก
    2. Login เข้าระบบโดยคลิกปุ่ม Login ตรงมุมขวาบนของหน้านี้ :roll:
    3. การ Login ผ่าน Facebook ดูวิธีที่ :arrow: Login ผ่าน Facebook
    4. ลืมรหัสผ่านสามารถรับรหัสใหม่ได้ที่ :arrow: Reset รหัสผ่าน
  3. มีปัญหาการใช้งาน แจ้งผู้ดูแลระบบได้ที่ :arrow: ติดต่อผู้ดูแลระบบ
  4. กำหนดการตั้งค่าส่วนตัว เช่นตั้งค่าภาษาเป็นไทยหรืออังกฤษดูได้ที่ :arrow: ตั้งค่าส่วนตัว
  5. การตั้งและตอบกระทู้ดูได้ที่ :arrow: วิธีการตั้งและตอบกระทู้
  6. การจัดรูปแบบตัวอักษรด้วย bbcode ในช่องแสดงความคิดเห็นดูได้ที่ :arrow: จัดรูปแบบตัวอักษร
  7. กำหนดขนาดตัวอักษรใน Browser ดูได้ที่ :arrow: กำหนดขนาดตัวอักษรใน Browser

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

ฟอรัมถาม-ตอบปัญหาการใช้งาน MS Excel and VBA
Forum rules
  1. ไม่อนุญาตให้ใช้ภาษาแชทในการถามและตอบปัญหา ไม่ใช้คำว่า "คับ" หรือ "อ่ะครับ" แทนคำว่า "ครับ" ไม่ใช้คำว่า "เด๋ว" แทนคำว่า "เดี๋ยว" เป็นต้น เนื่องจากเมื่อแปลเป็นภาษาต่างประเทศแล้วจะให้ความหมายผิดไปจากที่ควรจะเป็น
  2. ห้ามถามโดยระบุชื่อผู้ตอบและต้องตั้งชื่อกระทู้ให้สื่อถึงปัญหาที่จะถาม ไม่ตั้งชื่อว่า ช่วยด้วยครับ, มีปัญหามาปรึกษาครับ เป็นต้น
  3. กรุณาอธิบายปัญหาและระบุคำตอบที่ต้องการมาในกระทู้ด้วยเสมอถึงแม้จะอธิบายไว้ในไฟล์แนบแล้วก็ตาม ทั้งนี้เพื่ออำนวยความสะดวกแก่เพื่อนสมาชิกในการค้นหาข้อมูล
  4. กรุณาแนบไฟล์ตัวอย่างพร้อมแสดงคำตอบที่ถูกต้องมาในไฟล์ด้วยเพื่อให้ง่ายต่อการทำความเข้าใจและสะดวกต่อการตอบคำถาม (ขนาดไฟล์ไม่เกิน 500Kb ขนาดภาพไม่เกิน 800*600 Pixel) ไม่แนบเป็น Link มาจากแหล่งอื่นที่อาจจะถูกลบทิ้งไปโดยต้นทางในภายหลัง นอกจากนี้ไม่ควรแนบไฟล์ที่มีข้อมูลสำคัญอันก่อให้เกิดความเสียหายกับตนเองและผู้อื่น
  5. กรณีเป็นคำถามเกี่ยวกับ Programming เช่น VBA, VB.Net, C#, SQL ฯลฯ ต้องลองเขียนมาเองก่อนเสมอ ถามเฉพาะที่ติดปัญหา ระบุ Module, Procedure ที่ติดปัญหาให้ชัดเจน กรุณาโพสต์ Code ให้แสดงเป็น Code คือเปิดด้วย [code] และปิดด้วย [/code] ตัวอย่างเช่น [code]dim r as range[/code] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
  6. กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
godman
Silver
Silver
Posts: 643
Joined: Mon Jul 05, 2010 6:18 pm

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

#1

Post by godman »

คืออยากให้มันตังระหัสของ colump D โดยไม่ให้รหัสซ้ำกัน
ลองมา 2 ชั่วโมงแล้วไม่ได้ครับ
จะตั้งสูตรใน colump C อย่างไรดีครับใช้คอลัมพ์ A เป็นตัวตั้งครับ เช่น SUS.1.1
SUS.1.2 SUS.2.1
You do not have the required permissions to view the files attached to this post.
User avatar
snasui
Site Admin
Site Admin
Posts: 30761
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 365
Contact:

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

#2

Post 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:
You do not have the required permissions to view the files attached to this post.
godman
Silver
Silver
Posts: 643
Joined: Mon Jul 05, 2010 6:18 pm

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

#3

Post by godman »

คือในคอลัมพ์ D ว่างก็ให้มันว่างด้วยหละครับ สูตรยาวมากเลยนะเครับ ผมใช้ if ไป if มาจนพรุน
VEM 0 VEM.6.147
Cle n/a VEM.6.147 n/a
คือ ตรงนี้อะครับยังไม่เข้าเงือนไขครับ เพราะว่ามันควรจะเป็น Cle.n/a. อะไครับ คือให้มันดูที่ คอลัมพ์ D ครับถ้าไม่มีก็ไม่ให้มันแสดงอะไร
User avatar
snasui
Site Admin
Site Admin
Posts: 30761
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 365
Contact:

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

#4

Post by snasui »

:D ลองยกตัวอย่างมาให้เห็นภาพหน่อยครับ ส่งตัวอย่างมาใหม่ ทำเป็นตัวอย่างมาก็พอครับ ถ้ามี n/a ต้องการให้แสดงค่าอย่างไร ช่วยกรอกค่าที่ถูกต้องมาเป็นตัวอย่างให้ด้วยเช่นที่ทำมาจะดีมากครับ :mrgreen:
godman
Silver
Silver
Posts: 643
Joined: Mon Jul 05, 2010 6:18 pm

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

#5

Post by godman »

ถ้าคอลัมพ D ไม่มีหรือที่เป็น n/a ก็ไม่ให้แสดงค่าอะไรครับ
ผมแนบตัวอย่างมาใหม่ครัลบ
You do not have the required permissions to view the files attached to this post.
User avatar
snasui
Site Admin
Site Admin
Posts: 30761
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 365
Contact:

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

#6

Post 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 ลงด้านล่าง ลองดูตามไฟล์แนบครับ
You do not have the required permissions to view the files attached to this post.
godman
Silver
Silver
Posts: 643
Joined: Mon Jul 05, 2010 6:18 pm

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

#7

Post by godman »

ตรงตามความต้องการครับ ขอบพระคุณเป็นอย่างสูงครับ ผมนึกไม่ถึงจริงๆว่าปัญหานึกว่าจะง่าย แค่สูตร if อย่างเดียวก็น่าจะเอาอยู่ แต่ที่ใหนได้ซับซ้อนมากมายเลยจริงๆผมก็อยากจะได้คำอะิบายสูตรด้วย แต่รบกวนอาจารย์มากมายแล้ว เมื่อคืนก็อยู่ดึกมากเลยนะครับ ขอบคุณครับ
User avatar
snasui
Site Admin
Site Admin
Posts: 30761
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 365
Contact:

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

#8

Post 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 กับเซลล์สุดท้ายที่เป็นตัวเลข
godman
Silver
Silver
Posts: 643
Joined: Mon Jul 05, 2010 6:18 pm

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

#9

Post by godman »

อื้อ ครับ คงไม่แกะแล้วหละครับ
Post Reply