- ©«¤l
- 4901
- ¥DÃD
- 44
- ºëµØ
- 24
- ¿n¤À
- 4916
- ÂI¦W
- 246
- §@·~¨t²Î
- Windows 7
- ³nÅ骩¥»
- Office 20xx
- ¾\ŪÅv
- 150
- ©Ê§O
- ¨k
- ¨Ó¦Û
- ¥x¥_
- µù¥U®É¶¡
- 2010-4-30
- ³Ì«áµn¿ý
- 2024-11-12
|
- Sub ex()
- Dim ar()
- Set D = CreateObject("Scripting.Dictionary")
- Application.ScreenUpdating = False
- With Sheets.Add
- For Each sh In Sheets(Array("01", "02", "03", "04"))
- ReDim Preserve ar(s)
- ar(s) = sh.[A1].CurrentRegion.Address(, , xlR1C1, 1)
- s = s + 1
- Next
- .Range("A1").Consolidate Sources:=ar, Function:=xlSum, TopRow:=True, LeftColumn:=True, CreateLinks:=False
- For Each a In .Range(.[B1], .[IV1].End(xlToLeft))
- If IsEmpty(D(Split(a, "-")(0))) Then
- Set D(Split(a, "-")(0)) = a.Resize(.UsedRange.Rows.Count, 1)
- Else
- Set D(Split(a, "-")(0)) = Union(a.Resize(.UsedRange.Rows.Count, 1), D(Split(a, "-")(0)))
- End If
- Next
- Set Rng = .Range(.[A1], .[A65536].End(xlUp))
- For Each ky In D.keys
- With Sheets("SUM-" & ky)
- Rng.Copy .[A1]
- D(ky).Copy .[B1]
- End With
- Next
- Application.DisplayAlerts = False
- .Delete
- Application.DisplayAlerts = True
- End With
- Application.ScreenUpdating = True
- End Sub
½Æ»s¥N½X |
|