У меня есть таблица, показанная ниже, на основе подсвеченного желтым столбца, мне нужно сложить подсвеченные зеленым столбцы.
data:image/s3,"s3://crabby-images/86e6d/86e6df1f0f314d9831f60775ba80333070f76d3e" alt="enter image description here"
Ожидаемый результат здесь:
data:image/s3,"s3://crabby-images/dc14e/dc14e49909505a4379a7c191a1f8994009ed34e8" alt="enter image description here"
Я сделал это, используя приведенный ниже код…
Sub test()
lrow = ActiveSheet.Cells(ActiveSheet.Cells.Rows.Count, 1).End(xlUp).Row
Set Rng = Range("A2:A" & lrow)
For Each cell In Rng
If Not IsEmpty(cell) Then
a = cell
b = cell.Offset(0, 1)
c = cell.Offset(0, 5)
r = cell.Row
cnt = Application.WorksheetFunction.CountIf(Rng, cell)
d = 0
For i = 1 To cnt
If Cells(r + i, 1) = a And Cells(r + i, 2) = b And Cells(r + i, 6) Then
Cells(r, 7) = Cells(r + i, 7) + Cells(r, 7)
Cells(r, 8) = Cells(r + i, 8) + Cells(r, 8)
d = d + 1
End If
Next
If d > 0 Then Range(Cells(r + 1, 1).Address, Cells(r + d, 1).Address).EntireRow.Delete
End If
Next
End Sub
Я хочу сделать это с помощью словаря сценариев, которыйНовое для меня.Поскольку я новичок, я не могу изменить приведенный ниже пример кода, найденного в сети !!
Получил его с здесь
Sub MG02Sep59()
Dim Rng As Range, Dn As Range, n As Long, nRng As Range
Set Rng = Range(Range("A2"), Range("A" & Rows.Count).End(xlUp))
With CreateObject("scripting.dictionary")
.CompareMode = vbTextCompare
For Each Dn In Rng
If Not .Exists(Dn.Value) Then
.Add Dn.Value, Dn
Else
If nRng Is Nothing Then Set nRng = Dn Else Set nRng = Union(nRng, Dn)
.Item(Dn.Value).Offset(, 3) = .Item(Dn.Value).Offset(, 3) + Dn.Offset(, 3)
End If
Next
If Not nRng Is Nothing Then nRng.EntireRow.Delete
End With
End Sub
Может кто-нибудь помочьменя нет?с некоторыми примечаниями, если это возможно.