snasui.com ยินดีต้อนรับ
ยินดีต้อนรับสู่กระดานถามตอบ Excel and VBA และอื่น ๆ ที่เป็นมิตรกับทุกท่าน มีไฟล์แนบมหาศาล ช่วยให้ท่านค้นหาและติดตามศึกษาได้โดยง่าย สมาชิกท่านใดที่ยังไม่ได้ระบุ Version ของ Excel ที่ใช้งานจริง สามารถทำตาม Link นี้เพื่อจะได้รับคำตอบที่ตรงกับ Version ของท่านครับ ระบุ Version ของ Excel
ฟอรัมถาม-ตอบปัญหาการใช้งานสูตรและฟังก์ชัน Excel
Forum rules
ไม่อนุญาตให้ใช้ภาษาแชทในการถามและตอบปัญหา ไม่ใช้คำว่า "คับ" หรือ "อ่ะครับ" แทนคำว่า "ครับ" ไม่ใช้คำว่า "เด๋ว" แทนคำว่า "เดี๋ยว" เป็นต้น เนื่องจากเมื่อแปลเป็นภาษาต่างประเทศแล้วจะให้ความหมายผิดไปจากที่ควรจะเป็น
ห้ามถามโดยระบุชื่อผู้ตอบและต้องตั้งชื่อกระทู้ให้สื่อถึงปัญหาที่จะถาม ไม่ตั้งชื่อว่า ช่วยด้วยครับ, มีปัญหามาปรึกษาครับ เป็นต้น
กรุณาอธิบายปัญหาและระบุคำตอบที่ต้องการมาในกระทู้ด้วยเสมอถึงแม้จะอธิบายไว้ในไฟล์แนบแล้วก็ตาม ทั้งนี้เพื่ออำนวยความสะดวกแก่เพื่อนสมาชิกในการค้นหาข้อมูล
กรุณาแนบไฟล์ตัวอย่างพร้อมแสดงคำตอบที่ถูกต้องมาในไฟล์ด้วยเพื่อให้ง่ายต่อการทำความเข้าใจและสะดวกต่อการตอบคำถาม (ขนาดไฟล์ไม่เกิน 500Kb ขนาดภาพไม่เกิน 800*600 Pixel) ไม่แนบเป็น Link มาจากแหล่งอื่นที่อาจจะถูกลบทิ้งไปโดยต้นทางในภายหลัง นอกจากนี้ไม่ควรแนบไฟล์ที่มีข้อมูลสำคัญอันก่อให้เกิดความเสียหายกับตนเองและผู้อื่น
กรณีเป็นคำถามเกี่ยวกับ Programming เช่น VBA, VB.Net, C#, SQL ฯลฯ ต้องลองเขียนมาเองก่อนเสมอ ถามเฉพาะที่ติดปัญหา ระบุ Module, Procedure ที่ติดปัญหาให้ชัดเจน กรุณาโพสต์ Code ให้แสดงเป็น Code คือเปิดด้วย [code] และปิดด้วย [/code] ตัวอย่างเช่น [code]dim r as range[/code] เพื่อให้แตกต่างจากข้อความทั่วไป สะดวกในการอ่านและทดสอบ (คลิกเพื่อดูตัวอย่าง)
กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่
titus
Member
Posts: 89 Joined: Sun Aug 24, 2014 1:34 pm
#1
Post
by titus » Tue Oct 18, 2016 10:26 am
รบกวนช่วยดูมาโครด้วยครับ
ต้องการตัดรายการที่ซ้ำในแถว ทั้ง หมด 105 รายการ
คงเหลือที่ไม่ซ้ำ 86 รายการ
แต่พอมาเขียนมาโคร มันตัดเหลือแค่ 3 รายการ
แก้ไขจุดไหนดีครับ
Code: Select all
Sub removenameDup()
Sheets("ยอดบัญชี").Select
Columns("A:A").Select
Selection.Copy
Columns("E:E").Select
ActiveSheet.Paste
Application.CutCopyMode = False
Range("E1").Select
Range(Selection, Selection.End(xlDown)).Select
myrange1 = ActiveCell.Address
ActiveSheet.Range(myrange1).RemoveDuplicates Columns:=1, Header:=xlNo
ActiveWorkbook.Worksheets("ยอดบัญชี").Sort.SortFields.Clear
ActiveWorkbook.Worksheets("ยอดบัญชี").Sort.SortFields.Add Key:=Range( _
myrange1), SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:= _
xlSortNormal
With ActiveWorkbook.Worksheets("ยอดบัญชี").Sort
.SetRange Range(myrange1)
.Header = xlGuess
.MatchCase = False
.Orientation = xlTopToBottom
.SortMethod = xlPinYin
.Apply
End With
End Sub
DhitiBank
Gold
Posts: 1676 Joined: Mon Oct 15, 2012 12:07 am
#2
Post
by DhitiBank » Tue Oct 18, 2016 11:20 am
รบกวนทำไฟล์ตัวอย่างแนบมาด้วยได้ไหมครับ ตามกฎข้อ 4 ด้านบนเอามาแค่ตัวอย่างไม่ต้องส่งข้อมูลสำคัญนะครับ การจะดูว่าซ้ำหรือไม่ซ้ำคงต้องดูข้อมูลด้วยครับ บางทีเห็นว่าข้อความหรือตัวเลขเหมือนกัน แต่มันอาจไม่เหมือนกันจริงๆ ก็ได้ครับ
titus
Member
Posts: 89 Joined: Sun Aug 24, 2014 1:34 pm
#3
Post
by titus » Tue Oct 18, 2016 11:28 am
ได้เเล้ว ครับ เปลี่ยนเครื่อง มา ทำได้เฉยเลย ครับ
titus
Member
Posts: 89 Joined: Sun Aug 24, 2014 1:34 pm
#4
Post
by titus » Tue Oct 18, 2016 11:32 am
ไฟล์แนบครับ
You do not have the required permissions to view the files attached to this post.
DhitiBank
Gold
Posts: 1676 Joined: Mon Oct 15, 2012 12:07 am
#5
Post
by DhitiBank » Tue Oct 18, 2016 12:15 pm
อาจสามารถตัดบางบรรทัดทิ้งได้ครับ และแนะนำคำสั่ง sort อีกแบบหนึ่งครับ
Code: Select all
Public Sub Test()
Dim r As Range
With Sheets(1)
.Activate
.Range("e:e").Clear
Set r = .Range("a1:a" & .Range("a" & .Rows.Count).End(xlUp).Row)
r.Offset(, 4).Value = r.Value
r.Offset(, 4).RemoveDuplicates Columns:=1, Header:=xlNo
r.Offset(, 4).Sort key1:=.Range("e1") _
, order1:=xlAscending, Header:=xlNo
End With
End Sub