Excel: セル内のコンマ区切りの値 - あらゆる組み合わせで作成された行に展開されます

Excel: セル内のコンマ区切りの値 - あらゆる組み合わせで作成された行に展開されます

最初の表のようなものから 2 番目の表に移動したいと思います。

ここに画像の説明を入力してください

...ピボット テーブルで使用するためです。最初のテーブルを 1 つのシートに配置し、2 番目のテーブルを別のシートに配置して、この「展開された」2 番目のテーブルをライブ更新したいと思います。しばらく試していますが、うまくいきません。何か提案はありますか? 私が使用しているフォームは、このリスト タイプのコンマ区切りの値を単一のセルに出力していますが、この場合、行が数千になるため、手動で行うことは現実的ではありません。

答え1

スクリプトを修正しましたgtwebbが提供したリンクからスクリプトは次のとおりです。

Option Explicit

Sub Main()

Columns("B:B").NumberFormat = "@"
Dim i As Long, c As Long, r As Range, v As Variant

For i = 1 To Range("B" & Rows.Count).End(xlUp).Row
    v = Split(Range("B" & i), ", ")
    c = c + UBound(v) + 1
Next i

For i = 2 To c
    Set r = Range("B" & i)
    Dim arr As Variant
    arr = Split(r, ", ")
    Dim j As Long
    r = arr(0)
    For j = 1 To UBound(arr)
        Rows(r.Row + j & ":" & r.Row + j).Insert Shift:=xlDown
        r.Offset(j, 0) = arr(j)
        r.Offset(j, -1) = r.Offset(0, -1)
        r.Offset(j, 1) = r.Offset(0, 1)
    Next j
Next i

Columns("C:C").NumberFormat = "@"
Dim k As Long, d As Long, s As Range, w As Variant

For k = 1 To Range("C" & Rows.Count).End(xlUp).Row
    w = Split(Range("C" & k), ", ")
    d = d + UBound(w) + 1
Next k

For k = 2 To d
    Set s = Range("C" & k)
    Dim arrb As Variant
    arrb = Split(s, ", ")
    Dim m As Long
    s = arrb(0)
    For m = 1 To UBound(arrb)
        Rows(s.Row + m & ":" & s.Row + m).Insert Shift:=xlDown
        s.Offset(m, 0) = arrb(m)
        s.Offset(m, -1) = s.Offset(0, -1)
        s.Offset(m, -2) = s.Offset(0, -2)
    Next m
Next k
End Sub

これは 2 つの列にのみ必要だったので、ループは気にしませんでした。変更されたのは、スクリプトが 2 回目に繰り返されること、変数が変更されること、およびパラメーターがOffset変更されることだけです。

関連情報