2017-03-16 46 views
0

我愛brettdj的SliceNDice子:SliceNDice 3列

Split comma separated entries to new rows

我用它所有的時間。我現在有一個情況,現在有三列,在我的生活中 - 我無法弄清楚如何改變vba使其工作。第三列是用逗號分隔的值。前兩列是單個條目。第一次張貼我,所以我抓住了我的椅子武器,以防萬一我做了不正確的事情。

+1

跟着你發佈的鏈接的例子。發佈一些測試數據和預期結果以及您試圖按照自己的意願調整的實際代碼。然後解釋代碼錯誤地執行的具體內容。我們不是在這裏修改現有的工作代碼以適應您的需求。 –

回答

0

如果您嘗試在每個後續行中保留第一列和第二列,同時在第三列中添加每個分隔值,則應該可以工作。

Sub SliceNDice() 
Dim objRegex As Object 
Dim X 
Dim Y 
Dim lngRow As Long 
Dim lngCnt As Long 
Dim tempArr() As String 
Dim strArr 
Set objRegex = CreateObject("vbscript.regexp") 
objRegex.Pattern = "^\s+(.+?)$" 
'Define the range to be analysed 
X = Range([a1], Cells(Rows.Count, "c").End(xlUp)).Value2 
ReDim Y(1 To 3, 1 To 1000) 
For lngRow = 1 To UBound(X, 1) 
    'Split each string by "," 
    tempArr = Split(X(lngRow, 3), ",") 
    For Each strArr In tempArr 
     lngCnt = lngCnt + 1 
     'Add another 1000 records to resorted array every 1000 records 
     If lngCnt Mod 1000 = 0 Then ReDim Preserve Y(1 To 3, 1 To lngCnt + 1000) 
     Y(1, lngCnt) = X(lngRow, 1) 
     Y(2, lngCnt) = X(lngRow, 2) 
     Y(3, lngCnt) = objRegex.Replace(strArr, "$1") 

    Next 
Next lngRow 
'Dump the re-ordered range to columns C:D 
[d1].Resize(lngCnt, 3).Value2 = Application.Transpose(Y) 
End Sub 

的樣本數據: enter image description here

+0

謝謝RyanL。它像一個魅力。我曾嘗試修改代碼,並且與您的代碼非常接近,但我忘記更改「For Each strArr ...」循環中的一行。無論如何,現在它工作正常。斯科特在未來的職位,我會盡量更明確。 – mark52c

+0

@ mark52c好聽。如果此答案適用於您,請將其標記爲答案。謝謝。 – RyanL