[英]VBA Code to Copy Data from Row 2 to Last Row of Data on One Sheet and Paste to the First Empty Row of Another Sheet
[英]VBA code to search for a column data from one sheet to another and paste corresponding rows data onto first sheet
我是 VBA 的新手,我找不到任何解決問題的方法。 我有兩個包含數據的工作簿。 在 workbook1 中有一個名稱列 A。在 workbook2 中還有一個名稱 columnA 和從 B 列到 D 的其他數據。我需要在工作簿 1 的 A 列中從 workbook2 的 A 列中搜索名稱,如果名稱匹配我需要在 workbook1 中粘貼相應的行。 另請注意,在工作簿 2 中,同名的條目可能不止一個。因此,在這些情況下,必須將這些行值連接並粘貼到工作簿 1 上。
請幫忙
Dim AVals 作為新字典 Dim k As Long, j As Long, lastRow1 As Long, lastRow2 As Long Dim sh_1, sh_3 As Worksheet Dim MyName As String Dim tmpCollection As Collection Set sh_1 = Sheets("snipe-sample-assets blank") Dim鍵作為變體
inputRowMin = 1
inputRowMax = 288
inputColMin = 1
inputColMax = 9
equipmentCol = 4
dimensionCol = 9
Set equipmentDictionary = CreateObject("Scripting.Dictionary")
equipmentDictionary.CompareMode = vbTextCompare
Set inputSheet = Application.Sheets("Verizon WirelessNumbers_2021033")
Set inputRange = Range(Cells(inputRowMin, inputColMin), Cells(inputRowMax, inputColMax))
Set equipmentCollection = New Collection
For i = 1 To inputRange.Height
thisEquipment = inputRange(i, equipmentCol).Text
nextEquipment = inputRange(i + 1, equipmentCol).Text
thisDimension = inputRange(i, dimensionCol).Text
'The Strings are equal - add thisEquipment to collection and continue
If (StrComp(thisEquipment, nextEquipment, vbTextCompare) = 0) Then
equipmentCollection.Add thisDimension
'The Strings are not equal - add thisEquipment to collection and the collection to the dictionary
Else
equipmentCollection.Add thisDimension
equipmentDictionary.Add thisEquipment, equipmentCollection
Set equipmentCollection = New Collection
End If
Next
'Set sh_3 = Sheets("sheet2")
lastRow2 = sh_1.Range("A:A").Rows.Count
lastRow2 = sh_1.Cells(lastRow2, 2).End(xlUp).Row 'last used row in column 2
'MsgBox lastRow2
For j = 2 To lastRow2
MyName = UCase(sh_1.Cells(j, 2).Value)
For Each key In equipmentDictionary.Keys
If (StrComp(MyName, key, vbTextCompare) = 0) Then
Set tmpCollection = equipmentDictionary.Item(MyName)
For k = 1 To tmpCollection.Count
sh_1.Cells(j, 10).Value = tmpCollection.Item(k)
Next
End If
Next
Next j
快速滿足您的需求
'You declare all these based on where your data resides
sheetName1 = "Sheets1"
sheetName2 = "Sheets2"
wbName1 = activeworkbook.name
wbName2 = activeworkbook.name 'I've included this for where you might want to fork solution to work off two workbooks
'Loop through entries in sheetName1
iRows1 = 1
Do Until IsEmpty(workbooks(wbName1).sheets(sheetName1).cells(iRows1,1))
sourceName = workbooks(wbName1).sheets(sheetName1).cells(iRows1,1)
'Loop through entries in sheetName2
colB = ""
colC = ""
colD = ""
iRows2 = 1
Do Until IsEmpty(workbooks(wbName2).sheets(sheetName2).cells(iRows2,1))
if workbooks(wbName2).sheets(sheetName2).cells(iRows2,1) = sourceName then
'If there is a match then append. If you want to delimit, then you'd need to add in a delimiter & "," for example
colB = colB & workbooks(wbName2).sheets(sheetName2).cells(iRows2,2).text
colC = colC & workbooks(wbName2).sheets(sheetName2).cells(iRows2,3).text
colD = colD & workbooks(wbName2).sheets(sheetName2).cells(iRows2,4).text
end if
iRows2 = iRows2 + 1
Loop
if colB <> "" then
'Found something, send it to sheetName1
workbooks(wbName1).sheets(sheetName1).cells(iRows1,2) = colB
workbooks(wbName1).sheets(sheetName1).cells(iRows1,3) = colC
workbooks(wbName1).sheets(sheetName1).cells(iRows1,4) = colD
end if
iRows1 = iRows1 + 1
Loop
如果要為單獨的工作簿執行此操作,則需要分配一個 wbName2。 我對 ActiveWorkbook 的使用假定它將用完您要粘貼到的工作簿。 它還假設您已經打開了兩個工作簿。 我敢肯定,您可以自己弄清楚這一點。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.