Data sort & transfer to different sheet

kesh321

New Member
Joined
Jun 13, 2018
Messages
19
Hello,

I am trying to figure out this problem.

Basically I have 2 sheets with identical purpose - to reflect the stock.

The old sheet was messy and not sorted, no constant locations, duplicate locations, however I know that newer entries were added to the bottom.

So each location has 3 slots, like it is supposed to be, in the new sheet.
There are cases where, in the old sheet, you have 1 entry per location, no entries at all, or more than 3 entries.

What I need to achieve:

-Find last matching row in old sheet, compared to new sheet, column A.
-Copy over the last matching row from old data, to first matching row in the new sheet.
-Repeat until no more matches found.

What I've got so far:
Code:
Sub transfer()

Dim sh1 As Worksheet, sh2 As Worksheet, rng1 As Range, rng2 As Range


Set sh1 = Sheets("Main")
Set sh2 = Sheets("Data")


    For Each rng1 In sh2.Range("A2", sh2.Cells(Rows.Count, 2).End(xlUp))
        Set rng2 = sh1.Range("A2:A10").Find(rng1.Value, , xlValues, xlWhole)
            If Not rng2 Is Nothing Then
                rng2.Offset(, 1) = rng1.Offset(, 1).Value
            End If
            Next
End Sub

It finds the last matching row in old data, but copies over only one match, and not in the first matching row into new sheet.

Example, desired result in column C:

Sheet "Main" (new) - this is where i would need excel to paste my values to
[TABLE="class: grid, width: 500, align: center"]
<tbody>[TR]
[TD]LOCATION[/TD]
[TD]DESCRIPTION[/TD]
[TD]DESIRED
[/TD]
[/TR]
[TR]
[TD]100A
[/TD]
[TD][/TD]
[TD]<- Data!B2[/TD]
[/TR]
[TR]
[TD]100B[/TD]
[TD][/TD]
[TD][/TD]
[/TR]
[TR]
[TD]100C[/TD]
[TD][/TD]
[TD][/TD]
[/TR]
[TR]
[TD]101A[/TD]
[TD][/TD]
[TD]<- Data!B7[/TD]
[/TR]
[TR]
[TD]101B[/TD]
[TD][/TD]
[TD]<- Data!B6[/TD]
[/TR]
[TR]
[TD]101C[/TD]
[TD][/TD]
[TD]<- Data!B5[/TD]
[/TR]
[TR]
[TD]102A[/TD]
[TD][/TD]
[TD]<- Data!B10[/TD]
[/TR]
[TR]
[TD]102B[/TD]
[TD][/TD]
[TD]<- Data!B9[/TD]
[/TR]
[TR]
[TD]102C[/TD]
[TD][/TD]
[TD][/TD]
[/TR]
</tbody>[/TABLE]

Sheet "Data" (old) - this is where i would need excel to copy my values from
[TABLE="class: grid, width: 500, align: center"]
<tbody>[TR]
[TD]LOCATION[/TD]
[TD]DESCRIPTION[/TD]
[TD]<- cell[/TD]
[/TR]
[TR]
[TD]100[/TD]
[TD][TABLE="width: 186"]
<tbody>[TR]
[TD="class: xl65, width: 186"]packing supplies[/TD]
[/TR]
</tbody>[/TABLE]
[/TD]
[TD]b2[/TD]
[/TR]
[TR]
[TD]101[/TD]
[TD][TABLE="width: 186"]
<tbody>[TR]
[TD="class: xl65, width: 186"]IT hardware[/TD]
[/TR]
</tbody>[/TABLE]
[/TD]
[TD]b3[/TD]
[/TR]
[TR]
[TD]101[/TD]
[TD][TABLE="width: 186"]
<tbody>[TR]
[TD="class: xl65, width: 186"]medical supplies[/TD]
[/TR]
</tbody>[/TABLE]
[/TD]
[TD]b4[/TD]
[/TR]
[TR]
[TD]101[/TD]
[TD][TABLE="width: 186"]
<tbody>[TR]
[TD="class: xl65, width: 186"]medical supplies[/TD]
[/TR]
</tbody>[/TABLE]
[/TD]
[TD]b5[/TD]
[/TR]
[TR]
[TD]101[/TD]
[TD][TABLE="width: 186"]
<tbody>[TR]
[TD="class: xl65, width: 186"]medical supplies[/TD]
[/TR]
</tbody>[/TABLE]
[/TD]
[TD]b6[/TD]
[/TR]
[TR]
[TD]101[/TD]
[TD][TABLE="width: 186"]
<tbody>[TR]
[TD="class: xl65, width: 186"]furniture[/TD]
[/TR]
</tbody>[/TABLE]
[/TD]
[TD]b7[/TD]
[/TR]
[TR]
[TD][/TD]
[TD][/TD]
[TD]b8[/TD]
[/TR]
[TR]
[TD]102[/TD]
[TD][TABLE="width: 186"]
<tbody>[TR]
[TD="class: xl65, width: 186"]archive[/TD]
[/TR]
</tbody>[/TABLE]
[/TD]
[TD]b9[/TD]
[/TR]
[TR]
[TD]102[/TD]
[TD][TABLE="width: 186"]
<tbody>[TR]
[TD="class: xl65, width: 186"]metal bars[/TD]
[/TR]
</tbody>[/TABLE]
[/TD]
[TD]b10[/TD]
[/TR]
</tbody>[/TABLE]


So the end result would look like this:
[TABLE="class: grid, width: 500, align: center"]
<tbody>[TR]
[TD]LOCATION[/TD]
[TD]DESCRIPTION[/TD]
[/TR]
[TR]
[TD]100A[/TD]
[TD]packing supplies[/TD]
[/TR]
[TR]
[TD]100B[/TD]
[TD][/TD]
[/TR]
[TR]
[TD]100C[/TD]
[TD][/TD]
[/TR]
[TR]
[TD]101A[/TD]
[TD][TABLE="width: 186"]
<tbody>[TR]
[TD="class: xl65, width: 186"]furniture[/TD]
[/TR]
</tbody>[/TABLE]
[/TD]
[/TR]
[TR]
[TD]101B[/TD]
[TD]medical supplies[/TD]
[/TR]
[TR]
[TD]101C[/TD]
[TD]medical supplies[/TD]
[/TR]
[TR]
[TD]102A[/TD]
[TD]metal bars[/TD]
[/TR]
[TR]
[TD]102B[/TD]
[TD]archive[/TD]
[/TR]
[TR]
[TD]102C[/TD]
[TD][/TD]
[/TR]
</tbody>[/TABLE]


Any help appreciated.

Thanks,
Matt.​
 

Excel Facts

Excel Can Read to You
Customize Quick Access Toolbar. From All Commands, add Speak Cells or Speak Cells on Enter to QAT. Select cells. Press Speak Cells.
Hi & welcome to MrExcel.
You have Cross posted this here https://www.excelforum.com/excel-programming-vba-macros/1234209-data-transfer.html

While we do not prohibit Cross-Posting on this site, we do ask that you please mention you are doing so and provide links in each of the threads pointing to the other thread (see rule 13 here along with the explanation: Forum Rules).
This way, other members can see what has already been done in regards to a question, and do not waste time working on a question that may already be answered.
 
Upvote 0
Hi Fluff,

Sorry about that.

Im not going to receive any help in this matter on excelforum :/
So please consider this problem on-going.

Any help appreciated.

Basically I need a piece of code with a loop until condition is met (no more matches) and a way to get that last match and copy it over to 'Main' as the first value for that specific match (location)

I think I could take things from there, if someone could help with that bit.

Thanks,
Matt.
 
Upvote 0
How about
Code:
Sub transfer()
   Dim sh1 As Worksheet, sh2 As Worksheet
   Dim r As Long, a As Long
   Dim v1 As Variant, v2 As String, b As String
   
   Set sh1 = Sheets("Main")
   Set sh2 = Sheets("Data")
   With CreateObject("Scripting.dictionary")
      For r = sh2.Range("A" & Rows.Count).End(xlUp).row To 2 Step -1
         v1 = sh2.Range("A" & r).Value: v2 = sh2.Range("B" & r).Value
         If Not .exists(v1) Then
            .Add v1, Array(1, v2)
         ElseIf .Item(v1)(0) < 3 Then
            a = .Item(v1)(0) + 1: b = .Item(v1)(1) & "|" & v2
            .Item(v1) = Array(a, b)
         End If
      Next r
      For r = 2 To sh1.Range("A" & Rows.Count).End(xlUp).row Step 3
         a = Left(sh1.Range("A" & r), 3)
         If .exists(a) Then
            v1 = Split(.Item(a)(1), "|")
            If UBound(v1) > 0 Then
               sh1.Range("B" & r).Resize(UBound(v1) + 1).Value = Application.Transpose(Split(.Item(a)(1), "|"))
            Else
               sh1.Range("B" & r).Value = v1
            End If
         End If
      Next r
   End With
End Sub
 
Upvote 0
Hey Fluff,

Thank You that works great.

Appreciated a lot!

Please consider this problem as solved.
I would like to mark this thread as solved, but I can't see an option to do so anywhere.

Thanks,
Matt.
 
Last edited:
Upvote 0
Glad to help & thanks for the feedback.
This site doesn't support marking threads as solved.
 
Upvote 0

Forum statistics

Threads
1,224,823
Messages
6,181,177
Members
453,021
Latest member
Justyna P

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top