我有包含Excel中的人的詳細信息,這包含城市,地址和名稱Excel的VBA到列表複製到新的工作表
我需要搶市列,併爲每個城市工作表中的列表,然後複製從sheet1到新工作表的數據。
因此,如果例如我有一個名爲都柏林的城市,我需要創建一個名爲dublin的新工作表,進入列表,抓取所有名爲dublin的城市,將它們複製並粘貼到都柏林工作表中作爲其他列當然)
我正在使用宏的形式鏈接:http://www.mrexcel.com/forum/excel-questions/727407-visual-basic-applications-split-data-into-multiple-worksheets-based-column.html由mirabeau創建。
的代碼如下:
Sub columntosheets()
Const sname As String = "Sheet1" 'change to whatever starting sheet
Const s As String = "A" 'change to whatever criterion column
Dim d As Object, a, cc&
Dim p&, i&, rws&, cls&
Set d = CreateObject("scripting.dictionary")
With Sheets(sname)
rws = .Cells.Find("*", , , , xlByRows, xlPrevious).Row
cls = .Cells.Find("*", , , , xlByColumns, xlPrevious).Column
cc = .Columns(s).Column
End With
For Each sh In Worksheets
d(sh.Name) = 1
Next sh
Application.ScreenUpdating = False
With Sheets.Add(after:=Sheets(sname))
Sheets(sname).Cells(1).Resize(rws, cls).Copy .Cells(1)
.Cells(1).Resize(rws, cls).Sort .Cells(cc), 2, Header:=xlYes
a = .Cells(cc).Resize(rws + 1, 1)
p = 2
For i = 2 To rws + 1
If a(i, 1) <> a(p, 1) Then
If d(a(p, 1)) <> 1 Then
Sheets.Add.Name = a(p, 1)
.Cells(1).Resize(, cls).Copy Cells(1)
.Cells(p, 1).Resize(i - p, cls).Copy Cells(2, 1)
End If
p = i
End If
Next i
Application.DisplayAlerts = False
.Delete
Application.DisplayAlerts = True
Application.ScreenUpdating = True
End With
Sheets(sname).Activate
End Sub
以上是能夠爲每個城市創建的工作表,但不會將數據複製到新創建的工作表。如何才能做到這一點?我對VBA的知識非常有限,完全喪失了這一點。
您是否嘗試複製工作表,按城市排序,然後刪除您不需要的順序?這樣你就不必擔心複製任何東西。 – Lumigraphics