: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. กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
aumps
Member
Member
Posts: 39
Joined: Fri Jun 15, 2012 12:02 pm

จัดอันดับพร้อมรวมข้อมูลซ้ำ

#1

Post by aumps »

ผมมีข้อมูลที่ต้องการหาผลรวม เพื่อจัดอันดับ แต่ข้อมูลเกิดซ้ำกัน ต้องใช้สูตรไหนได้บ้างครับ
ขอบคุณมาก ๆ ครับ
You do not have the required permissions to view the files attached to this post.
User avatar
DhitiBank
Gold
Gold
Posts: 1676
Joined: Mon Oct 15, 2012 12:07 am

Re: จัดอันดับพร้อมรวมข้อมูลซ้ำ

#2

Post by DhitiBank »

ลองแบบนี้ครับ

ที่ D2 คีย์
=INDEX($B$2:$B$11,SMALL(IF(IF(FREQUENCY(SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11))=LARGE(IF(FREQUENCY(SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)),ROWS(D$2:D2)),ROW($B$2:$B$11)-ROW($B$2)+1),1))
กด Ctrl+Shift ค้าง แล้ว Enter -> คัดลอกลงล่างจนเห็นค่าผิดพลาด

ที่ E2 คีย์
=IF(ISTEXT(D2),SUMIF($B$2:$B$11,D2,$C$2:$C$11),0)
Enter -> คัดลอกลงล่างครับ
User avatar
logic
Gold
Gold
Posts: 1510
Joined: Thu Mar 18, 2010 1:57 pm
Excel Ver: 365

Re: จัดอันดับพร้อมรวมข้อมูลซ้ำ

#3

Post by logic »

อันนี้หายอดขึ้นมาก่อนครับ :)

E2 =IFERROR(LARGE(IF(FREQUENCY(MATCH(SUMIF($B$2:$B$11,$B$3:$B$11,$C$2:$C$11),SUMIF($B$2:$B$11,$B$3:$B$11,$C$2:$C$11),0),ROW($B$2:$B$11)-ROW($B$2)+1),SUMIF($B$2:$B$11,$B$3:$B$11,$C$2:$C$11)),ROWS($E$2:E2)),"")

D2 =IF(N(E2),INDEX($B$2:$B$11,SMALL(IF(SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)=E2,ROW($B$2:$B$11)-ROW($B$2)+1),COUNTIF(E$2:E2,E2))),"")
ทั้งสองสูตรต้องกดแป้นแบบ Array คือ ctrl+shift+enter
User avatar
DhitiBank
Gold
Gold
Posts: 1676
Joined: Mon Oct 15, 2012 12:07 am

Re: จัดอันดับพร้อมรวมข้อมูลซ้ำ

#4

Post by DhitiBank »

DhitiBank wrote:ลองแบบนี้ครับ

ที่ D2 คีย์
=INDEX($B$2:$B$11,SMALL(IF(IF(FREQUENCY(SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11))=LARGE(IF(FREQUENCY(SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)),ROWS(D$2:D2)),ROW($B$2:$B$11)-ROW($B$2)+1),1))
กด Ctrl+Shift ค้าง แล้ว Enter -> คัดลอกลงล่างจนเห็นค่าผิดพลาด

ที่ E2 คีย์
=IF(ISTEXT(D2),SUMIF($B$2:$B$11,D2,$C$2:$C$11),0)
Enter -> คัดลอกลงล่างครับ
สูตรเดิมนี้จะแสดงข้อมูลไม่ถูกต้องหากมีอักษรบางตัวบังเอิญมีผลรวมเท่ากัน ขอปรับสูตรใหม่เป็น
F2
=INDEX($B$2:$B$11,MATCH(0,IF((COUNTIF($B$2:$B$11,"<"&$B$2:$B$11)+1)*COUNTIF(F$1:F1,$B$2:$B$11),1,0),0))
Ctrl+Shift+Enter

G2
=SUMIF($B$2:$B$11,F2,$C$2:$C$11)
Enter

E2
=LARGE($G$2:$G$11,ROWS(E$2:E2))
Enter

D2
=INDEX($F$2:$F$11,SMALL(IF($G$2:$G$11=E2,ROW($G$2:$G$11)-ROW($G$2)+1),COUNTIF(E$2:E2,E2)))
Ctrl+Shift+Enter

แล้วคัดลอกสูตรทั้งหมดลงล่างจนเห็นว่าแสดงค่าผิดพลาดครับ (สูตรในคอลัมน์ F และ G เอามาช่วยหาอักษรที่ไม่ซ้ำและผลรวมของแต่ละตัว)

:arrow: ส่วนเรื่อง conditional format ลองแบบนี้ครับ
(เอา conditional format เดิมออกก่อนครับ)
1. ลากคลุม B2:B11 -> Conditional format -> New Rule -> Use a formula to determine...
2. ที่ช่อง Format values where this formula is true: คีย์
=AND(B2=$D$2,COUNTIF($B$2:$B$11,$D$2)>1)
-> แล้วตั้งค่าสีพื้นหลังที่ชอบ -> OK
3. วนทำใหม่เรื่อยๆ จนครบตัวอักษร โดยเปลี่ยน D2 เป็นตำแหน่งอื่นครับ
User avatar
logic
Gold
Gold
Posts: 1510
Joined: Thu Mar 18, 2010 1:57 pm
Excel Ver: 365

Re: จัดอันดับพร้อมรวมข้อมูลซ้ำ

#5

Post by logic »

logic wrote:อันนี้หายอดขึ้นมาก่อนครับ :)

E2 =IFERROR(LARGE(IF(FREQUENCY(MATCH(SUMIF($B$2:$B$11,$B$3:$B$11,$C$2:$C$11),SUMIF($B$2:$B$11,$B$3:$B$11,$C$2:$C$11),0),ROW($B$2:$B$11)-ROW($B$2)+1),SUMIF($B$2:$B$11,$B$3:$B$11,$C$2:$C$11)),ROWS($E$2:E2)),"")

D2 =IF(N(E2),INDEX($B$2:$B$11,SMALL(IF(SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)=E2,ROW($B$2:$B$11)-ROW($B$2)+1),COUNTIF(E$2:E2,E2))),"")
ทั้งสองสูตรต้องกดแป้นแบบ Array คือ ctrl+shift+enter
ปรับ E2 ใหม่เป็นด้านล่างนะครับ (ส่วน D2 ใช้สูตรเดิม)

E2 =IFERROR(LARGE(IF(FREQUENCY(MATCH($B$2:$B$11,$B$2:$B$11,0),ROW($B$2:$B$11)-ROW($B$2)+1),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)),ROWS(P$2:P2)),"")
menem
Silver
Silver
Posts: 549
Joined: Mon Jan 26, 2015 11:02 am

Re: จัดอันดับพร้อมรวมข้อมูลซ้ำ

#6

Post by menem »

เนื่องจากเขียนสูตรที่เป็น Array ไม่เป็น ก็เลยใช้วิธีคิดทีละช่วงแทนครับ
You do not have the required permissions to view the files attached to this post.
User avatar
DhitiBank
Gold
Gold
Posts: 1676
Joined: Mon Oct 15, 2012 12:07 am

Re: จัดอันดับพร้อมรวมข้อมูลซ้ำ

#7

Post by DhitiBank »

ขอแก้อีกครั้งเถอะครับ ครั้งสุดท้ายแล้ว :tt:

D2
=INDEX($B$2:$B$11,SMALL(IF(IF(FREQUENCY(MATCH($B$2:$B$11&SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),$B$2:$B$11&SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),0),MATCH($B$2:$B$11&SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),$B$2:$B$11&SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),0)),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11))=E2,ROW($C$2:$C$11)-ROW($C$2)+1),COUNTIF(E$2:E2,E2)))
Ctrl+Shift+Enter

E2
=LARGE(IF(FREQUENCY(MATCH($B$2:$B$11&SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),$B$2:$B$11&SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),0),MATCH($B$2:$B$11&SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),$B$2:$B$11&SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11),0)),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)),ROWS(E$2:E2))
Ctrl+Shift+Enter

แล้วคัดลอกทั้งสองสูตรลงล่างจนเห็นค่าผิดพลาดครับ คราวนี้หากมีบังเอิญผลรวมของอักษรเท่ากันก็ไม่มีปัญหาครับ
aumps
Member
Member
Posts: 39
Joined: Fri Jun 15, 2012 12:02 pm

Re: จัดอันดับพร้อมรวมข้อมูลซ้ำ

#8

Post by aumps »

ขอขอบคุณ
คุณ DhitiBank
คุณ logic
คุณ menem
มาก ๆ ครับ สูตรทั้งหมดลองแล้วได้หมดเลยครับ :P ^ ^
aumps
Member
Member
Posts: 39
Joined: Fri Jun 15, 2012 12:02 pm

Re: จัดอันดับพร้อมรวมข้อมูลซ้ำ

#9

Post by aumps »

logic wrote:อันนี้หายอดขึ้นมาก่อนครับ :)

E2 =IFERROR(LARGE(IF(FREQUENCY(MATCH(SUMIF($B$2:$B$11,$B$3:$B$11,$C$2:$C$11),SUMIF($B$2:$B$11,$B$3:$B$11,$C$2:$C$11),0),ROW($B$2:$B$11)-ROW($B$2)+1),SUMIF($B$2:$B$11,$B$3:$B$11,$C$2:$C$11)),ROWS($E$2:E2)),"")

D2 =IF(N(E2),INDEX($B$2:$B$11,SMALL(IF(SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)=E2,ROW($B$2:$B$11)-ROW($B$2)+1),COUNTIF(E$2:E2,E2))),"")
ทั้งสองสูตรต้องกดแป้นแบบ Array คือ ctrl+shift+enter
แต่ในส่วนของ คุณ logic พบว่าพอลองใส่ข้อมูลเพิ่มแล้ว
หากตัวอักษรที่ซ้ำ มีค่าเท่ากันจะแสดงตัวแรกที่พบครับ
แบบที่คุณ DhitiBank พบเลยครับ
User avatar
snasui
Site Admin
Site Admin
Posts: 30917
Joined: Sun Jan 24, 2010 12:33 pm
Location: Songkhla, Thailand
Excel Ver: 2010, 365
Contact:

Re: จัดอันดับพร้อมรวมข้อมูลซ้ำ

#10

Post by snasui »

:D ตัวอย่างเพิ่มเติมครับ
  1. E2 คีย์
    =IFERROR(LARGE(IF(FREQUENCY(MATCH($B$2:$B$11,$B$2:$B$11,0),ROW($B$2:$B$11)-ROW($B$2)+1),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11)),ROWS(P$2:P2)),"")
    Ctrl+Shift+Enter > Copy ลงด้านล่าง
  2. D2 คีย์
    =IF(N(E2),INDEX($B$2:$B$11,SMALL(IF(IF(FREQUENCY(MATCH($B$2:$B$11,$B$2:$B$11,0),ROW($B$2:$B$11)-ROW($B$2)+1),SUMIF($B$2:$B$11,$B$2:$B$11,$C$2:$C$11))=$E2,ROW($B$2:$B$11)-ROW($B$2)+1),COUNTIF(E$2:E2,E2))),"")
    Ctrl+Shift+Enter > Copy ลงด้านล่าง
Post Reply