Посмотрите, работает ли это для вас.
Вам необходимо создать новый рабочий лист в вашей рабочей книге и установить техническое имя на shTransformed . Сделайте это, зайдя в редактор VBA (Alt + F11) и изменив его, как показано ниже ...
data:image/s3,"s3://crabby-images/e7372/e7372e190ee4731481aa0c4ed6cfb0cf6b642daf" alt="How to change the technical name of the worksheet"
Затем добавьте новый модуль (в редакторе VBA перейдите на Вставка-> Модуль ) и добавьте код, как показано ниже ...
Public Sub TransformToColumnsByAcct()
Dim rngSrcData As Range, i As Long, objDict As Scripting.Dictionary, strKey As String, arrRows As Variant
Dim lngHeaderStartCol As Long, x As Long, lngSrcRow As Long, lngWriteRow As Long, lngMaxUbound As Long
Set rngSrcData = Selection
Set objDict = New Scripting.Dictionary
With rngSrcData
' Get all of the unique accounts, this will also determine for us the amount of columns we need to provide for.
' Start from the 2nd row because the 1st contains the header.
For i = 2 To .Rows.Count
strKey = .Cells(i, 1)
If Not objDict.Exists(strKey) Then
objDict.Add strKey, Array(i)
Else
arrRows = objDict.Item(strKey)
ReDim Preserve arrRows(UBound(arrRows) + 1)
arrRows(UBound(arrRows)) = i
objDict.Item(strKey) = arrRows
If UBound(arrRows) > lngMaxUbound Then
lngMaxUbound = UBound(arrRows)
End If
End If
Next
' Clear all of the cells in the destination worksheet.
shTransformed.Cells.Clear
' Add the header for the key field.
shTransformed.Cells(1, 1) = .Cells(1, 1)
lngHeaderStartCol = 2
' Now get all of the column headers excluding the first as this contains the key and write them to the
' transformed worksheet. Dynamically increment the 2nd header by 1 each time.
For i = 1 To lngMaxUbound + 1
' Determine the start column for the header to be copied to factoring in the first field.
If i > 1 Then
lngHeaderStartCol = lngHeaderStartCol + .Columns.Count - 1
End If
.Range(.Cells(1, 2).Address & ":" & .Cells(1, .Columns.Count).Address).Copy shTransformed.Cells(1, lngHeaderStartCol)
' Incremement the header text by 1 and put an underscore.
shTransformed.Cells(1, lngHeaderStartCol) = shTransformed.Cells(1, lngHeaderStartCol) & "_" & i
Next
' Now write out all of the unique keys to the transformed sheet along with the data.
For i = 0 To objDict.Count - 1
strKey = objDict.Keys(i)
arrRows = objDict.Item(strKey)
lngWriteRow = i + 2
' Write the key to the first column.
shTransformed.Cells(lngWriteRow, 1) = strKey
lngHeaderStartCol = 2
' Now process each row of data for the unique key.
For x = 0 To UBound(arrRows)
lngSrcRow = arrRows(x)
If x > 0 Then
lngHeaderStartCol = lngHeaderStartCol + .Columns.Count - 1
End If
' Copy the data for the given row to the transformed sheet.
.Range(.Cells(lngSrcRow, 2).Address & ":" & .Cells(lngSrcRow, .Columns.Count).Address).Copy shTransformed.Cells(lngWriteRow, lngHeaderStartCol)
Next
Next
End With
End Sub
Далее в редакторе VBA перейдите на Инструменты-> Ссылки и добавьте ссылку ...
Microsoft Scripting Runtime
Теперь вернитесь на свой лист с необработанными данными, выберите все и перейдите к Разработчик-> Макросы (Если вы не видите меню разработчика на своей ленте, найдите его в Google). запустите макрос и посмотрите, как он работает.
Если вы посмотрите на преобразованный лист, вы должны увидеть свой результат.
data:image/s3,"s3://crabby-images/bc1f9/bc1f963d3dc36f0d4891cb6ed98bf4466042f612" alt="Result"
Вот надеемся, что это сработает для вас.