2013-04-08 156 views

回答

3

試試這個代碼:

Sub Remove_All_Duplicated() 
Dim Array_1 
    Array_1 = Array("pedro", "maria", "jose", "jesus", "pepe", "pepe", "jose") 
Dim Array_2() 

Dim eleArr_1, x 
x = 0 
For Each eleArr_1 In Array_1 
    If UBound(Filter(Array_1, eleArr_1)) = 0 Then 
     ReDim Preserve Array_2(x) 
     Array_2(x) = eleArr_1 
     x = x + 1 
    End If 
Next 

End Sub 

其他搜索解決方案ñFilter功能不關心「精確匹配」。這個新的需要參考VBA項目中的Microsoft Scripting Runtime。

Sub alternative() 
Dim Array_1 
    Array_1 = Array("pedro", "pedro maria", "maria", "jose", "jesus", "pepe", "pepe", "jose") 
Dim Array_2() 
Dim Array_toRemove() 

Dim dic As New Scripting.Dictionary 
Dim arrItem, x As Long 
For Each arrItem In Array_1 
    If Not dic.Exists(arrItem) Then 
     dic.Add arrItem, arrItem 
    Else 
     ReDim Preserve Array_toRemove(x) 
     Array_toRemove(x) = dic.Item(arrItem) 
     x = x + 1 
    End If 
Next 
For Each arrItem In Array_toRemove 
    dic.Remove (arrItem) 
Next arrItem 
Array_2 = dic.Keys 

'quic tests to remove when unnecessary 
Debug.Print UBound(Array_2), UBound(Array_toRemove) 
Debug.Print Join(Array_2, "/") 

End Sub 
+0

感謝我也是我看到了實際使用的**使用ReDim保留** – 2013-04-08 11:34:53

+1

我很高興你喜歡這個解決方案。但是,我已經意識到首先想法的一些缺點,因此我添加了其他解決方案。 – 2013-04-08 13:12:57

0

如何創建一個新的A_temp1()不重複,使用過濾器()VBA函數:

Dim A_temp1() As String 
    Dim NUMERO1 As Long 
    Dim NUMERO2 As Long 
    Dim DATO1 As Variant 

NUMERO1 = 0 
For Each DATO1 In Array_1 
    If UBound(Filter(Array_1, DATO1)) > 0 Then 
     Array_1(NUMERO1) = vbNullString 
    End If 
    NUMERO1 = NUMERO1 + 1 
Next DATO1 

NUMERO2 = 0 
For NUMERO1 = LBound(Array_1) To UBound(Array_1) 
    If Array_1(NUMERO1) <> vbNullString Then 
    ReDim Preserve A_temp1(NUMERO2) 
    A_temp1(NUMERO2) = Array_1(NUMERO1) 
    NUMERO2 = NUMERO2 + 1 
    End If 
Next NUMERO1 
0

這裏是另一個版本:

Public Sub ShortVersion() 
    Dim varInput: varInput = Array("pedro", "pedro maria", "maria", "jose", "jesus", "pepe", "pepe", "jose") 
    Dim colOutput As Collection: Set colOutput = New Collection 
    Dim i As Long: For i = LBound(varInput) To UBound(varInput) 
     If UBound(Split(Chr(1) & Join(varInput, Chr(1) & Chr(1)) & Chr(1), Chr(1) & varInput(i) & Chr(1))) = 1 Then 
      colOutput.Add varInput(i) 
     End If 
    Next i 
End Sub 

優點:

  • 較短碼
  • 的決定標準是獨立循環的後面的迭代的,所以如果你在你的算法構建它,你可以用第一個元素進行而無需等待有關後來者
  • 決定不依賴於MS腳本運行

缺點:

  • 效率較低對於更大的陣列
  • 輸出集合而不是數組(需要一個循環轉換成數組,如果是需要的話)
  • 假設數組只包含文本和ASCII 1(SOH)不 出現的任何地方(這是很可能的,然而)