: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

ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน array

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. กรุณาแจ้งผลการใช้งานเมื่อได้รับคำตอบว่าตรงกับความต้องการหรือไม่

Post a reply


This question is a means of preventing automated form submissions by spambots.
Smilies
:D :thup: :cp: :flw: :rz: :sg: :tt: :) ;) :( :o :shock: :? 8-) :lol: :x :P :oops: :cry: :evil: :twisted: :roll: :!: :?: :idea: :arrow: :ard: :arl: :aru: :| :mrgreen: :geek: :ugeek:

BBCode is ON
[img] is ON
[url] is ON
Smilies are ON

Topic review
   

Expand view Topic review: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน array

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#19

by angleblack » Tue Jun 11, 2013 10:33 am

ขอบคุณมากครับ ทีให้คำแนะนำ

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#18

by snasui » Fri May 31, 2013 2:20 pm

:D คำว่า ป่าว ควรเป็น เปล่า หรือคำว่า หรือไม่ แทน ส่วนคำว่า อ่ะ ไม่จำเป็นต้องใช้ครับ

ช่วยทำไฟล์ตัวอย่างที่บอกว่าไม่ได้แนบมาด้วย จะได้ช่วยทดสอบได้ Code นั้นผมแจ้งไปแล้วว่าเครื่องผมทำงานได้เป็นปกติครับ :roll:

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#17

by angleblack » Fri May 31, 2013 2:09 pm

พอมีวิธีช่วยผมหน่อยได้รึป่าวครับ งง มากเลย ครับ

Code: Select all

last_row = Range("B" & Rows.Count).End(xlUp).Row
            start_row = 2
            
            For i = start_row To last_row
                arrhd = Split(Cells(i, 2).Value, "@")
Resultname = arrhd(0)
Resultname1 = arrhd(1)
Resultname2 = arrhd(2)
ผมใช้ Code ชุดนี้ สามารถ Get ค่า string ลง Resultname ได้อ่ะครับ

แต่พอใช้Code

Code: Select all

  For i = start_row To last_row
                Dim aa As New Collection
                Dim b() As Variant
                Dim k As Variant
                Dim j As Integer
                Dim z As Integer
                z = 1
                arrhd = Split(Cells(i, 2).Value, "@")
                On Error Resume Next
                For Each k In arrhd
                    aa.Add k, k
                Next k
                On Error GoTo 0
                ReDim b(0 To aa.Count - 1)
                For j = 0 To aa.Count - 1
                    b(j) = aa(j + 1)
                Next j
                Resultame = b(0)
                Resultame1 = b(1)
                Resultame2 = b(2)
แต่Getค่า ลงResultame ไม่ได้ มันผิดปกติตรงไหนหรอครับช่วยบอกหน่อย

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#15

by snasui » Wed May 29, 2013 10:09 am

:D ลองตรวจสอบว่ามีการกำหนดเป็น Option Base 1 เพื่อให้ Array เริ่มขอบเขตล่างที่ 1 แทนที่จะเป็น 0 ไว้หรือไม่ครับ

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#14

by angleblack » Wed May 29, 2013 9:45 am

ครับ ผมแค่แปลกใจว่าทำไหม Resultame ถึงไม่ยอมเก็บค่า string ของ b(0)

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#13

by snasui » Wed May 29, 2013 9:41 am

:lol: เครื่องผมทำงานได้เป็นปกติครับ ไม่ว่าจะเท่ากับ b(0) หรือ b(n)

Note: n คือ ตำแหน่งใด ๆ ใน Array b

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#12

by angleblack » Wed May 29, 2013 9:30 am

ผมได้ทำการลองเล่น มาทั้งคืน ครับ
Resultame ไม่ยอมรับค่า string จาก b(0) ผมก็ได้ตั้ง ให้ Resultame เป็น string แล้วนะครับ

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#11

by snasui » Tue May 28, 2013 1:55 pm

:D ตัวอย่าง Code ครับ

Code: Select all

Sub testUniqueValInArray()
    Dim arrhd As Variant, aa As New Collection
    Dim b() As Variant, k As Variant
    Dim j As Integer, i As Integer
    i = 1
    arrhd = Split(Cells(i, 2).Value, "@")
    On Error Resume Next
    For Each k In arrhd
        aa.Add k, k
    Next k
    On Error GoTo 0
    ReDim b(0 To aa.Count - 1)
    For j = 0 To aa.Count - 1
        b(j) = aa(j + 1)
    Next j
    Resultame = b(0)
End Sub

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#10

by angleblack » Tue May 28, 2013 11:59 am

ผมตั้ง

Dim aa As New Collection


ครับ

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#9

by snasui » Tue May 28, 2013 11:41 am

:D Code ที่ Post มาไม่เห็นว่ามีการใช้ Collection เข้ามาช่วย ลอง Post Code ดังกล่าวมาด้วยครับ

หลักการคือ นำ Array ต้นแหล่งไป Loop เพื่อ Add เข้า Collection ซึ่งจะ Add เข้าไปได้เฉพาะค่าที่ไม่ซ้ำ

จากนั้นนำ Collection กลับมาใส่ Array ซึ่งจะได้ Array ของค่าที่ไม่ซ้ำ

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#8

by angleblack » Tue May 28, 2013 11:09 am

ผมลองใช้ละครับ

Code: Select all

 arrhd = Split(Cells(I, 2).Value, "@")
            'aa.Add arrhd()
            Resultame = arrhd(0)
            ' If Not (arrhd()) Then
            ' Resultname = aa.Add arrhd()
            ' End If
               ' arrhd = Split(Cells(I, 2).Value, "@")
               '     Resultname = arrhd(0)
ก็ยังไม่ไม่ได้ครับ ลองใช้ Collection ดึงมาหมดทุกคำ แล้วลองใช้ If Not แบบ vb ก็ไม่ผ่าน แต่เดียวลองหาวิธีอื่นก่อนครับ

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#7

by snasui » Mon May 27, 2013 5:28 pm

:D สามารถใช้ Collection เข้ามาช่วยได้ ลองดูตัวอย่างที่นี่ครับ http://www.mrexcel.com/forum/excel-ques ... ost1501481

สำหรับการ Post Code ให้เป็น Code ดูที่นี่ครับ http://www.snasui.com/viewtopic.php?f=2&t=1187

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#6

by angleblack » Mon May 27, 2013 4:14 pm

Function GetResultName(ByVal Resultbook As Workbook) As Variant

Dim Item As Variant
Dim Count, NumUnique, CountResult, CountDup As Integer
Dim Resultname As String


Dim Element() As Variant
Dim FoundMatch As Boolean
'''Dim Returnindex As Integer: Returnindex = 0 '' index of _error, _Result

Count = 0
NumUnique = 0
CountResult = 0
On Error GoTo ResultNotFound

Resultbook.Sheets("Result (2)").Select
With ActiveSheet


last_row = Range("B" & Rows.Count).End(xlUp).Row
'last_row = 7
start_row = 2

For I = start_row To last_row
arrhd = Split(Cells(I, 2).Value, "@")
Resultname = arrhd(0)



If Resultname = "" Then
GoTo ResultNotFound
Else
ReDim Preserve Element(0 To Count)
Element(Count) = Resultname
Count = Count + 1
End If
Next


'''/// fine Unique name of Format '''
If Count > 0 Then
For Each Item In Element
FoundMatch = False
If NumUnique = 0 Then
FoundMatch = False
GoTo AddItem '(Exit For-Next loop)
End If
'Has item been added yet?
For I = 0 To NumUnique - 1
If Item = CountResultByLocation(I).Resultname Then
FoundMatch = True
CountDup = CountResultByLocation(I).ResultNumber + 1
CountResultByLocation(I).ResultNumber = CountDup
End If
Next I

AddItem:
' If not in list, add the item to unique list
If Not FoundMatch Then
CountResult = 1
ReDim Preserve CountResultByLocation(NumUnique)
CountResultByLocation(NumUnique).ResultNumber = CountResult
CountResultByLocation(NumUnique).Resultname = Item
NumUnique = NumUnique + 1
End If

Next Item

GetResultName = True

Exit Function
Else
GoTo ResultNotFound
End If



End With


ResultNotFound:

GetResultName = False
End Function


arrhd เก็บค่าเป็น array ผมต้องการทีจะ ให้ แสดงข้อมูลทีเก็บใน arrhd ออกโดยเอาค่าืทีไม่ได้ ซ้ำกัน ออกมา โชว์ใน Resultname ตอนนี้ผมสามารถทำให้ Resultname แสดงค่า แรกของ array ออกมาได้ แต่ว่า ผมคิดไม่ออกว่าจะทำยังไงให้ แสดงค่า ทีไม่ซ้ำกันใน array ออกมานะครับ เลยมาขอคำแนะนำ ขอโทษด้วยครับที แนบ ไฟล์มาไม่ได้เพราะว่า มันต้องมีดึง ข้อมูลจาก ไฟล์ excel มาเก็บค่าแล้วก็นำมาหาค่าอ่ะครับ

Re: ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน ar

#5

by snasui » Mon May 27, 2013 4:00 pm

angleblack wrote:arrhd = Split(Cells(I, 2).Value, "@")
Resultname = arrhd(0)

ใน array() arrhdมีค่า a,b,c,a,c

ผมต้องการจะให้นำเอาค่าทีซ้ำกันใน arrhd มาshowใน Resultname
:D จากคำถามด้านบน คำตอบของ Resultname คือค่าใดครับ

ควรแนบไฟล์พร้อม Code มาด้วย เพื่อนสมาชิกจะได้ช่วยทดสอบได้ครับ

Re: ขอความรู้ ภาษา VBA หน่อยคับ ต้องการจะเอาค่าทีไม่ซ้ำใน ar

#4

by snasui » Mon May 27, 2013 3:09 pm

:twisted: ช่วยอ่านกฎการใช้บอร์ดด้านบนอีกครั้ง ในฟอรัมถามตอบห้ามใช้ภาษาแชทครับ ถ้าเขียนคำว่า ครับ เป็น คับ มาอีกรอบโดยเจตนาจะโดนแบนครับ :evil:

การหาค่าซ้ำใน array

#3

by angleblack » Mon May 27, 2013 2:39 pm

arrhd = Split(Cells(I, 2).Value, "@")
Resultname = arrhd(0)

ใน array() arrhdมีค่า a,b,c,a,c

ผมต้องการจะให้นำเอาค่าทีซ้ำกันใน arrhd มาshowใน Resultname

Re: ขอความรู้ ภาษา VBA หน่อยคับ ต้องการจะเอาค่าทีไม่ซ้ำใน ar

#2

by logic » Mon May 27, 2013 2:31 pm

:shock: คงไม่มีคนกล้าช่วย เพราะผิดกฎข้อ 1 ครับ

ช่วยอ่านกฎทุกข้อก่อนครับ :roll:

ขอความรู้ ภาษา VBA หน่อยครับ ต้องการจะนำค่าทีไม่ซ้ำใน array

#1

by angleblack » Mon May 27, 2013 2:22 pm

arrhd = Split(Cells(I, 2).Value, "@")
Resultname = arrhd(0)

ตอนนี้คือว่า ใน array() arrhdมี a,b,c,a,c

ผมต้องการจะให้มันเอา ค่าทีซ้ำกันใน arrhd มาshowใน Resultname

Top