Copy rows, paste to new worksheet, rename new worksheet, return to Source material

fuzzyizzabear

New Member
Joined
Feb 10, 2020
Messages
1
Restarting my VBA education after several years away, and am stumped on what I imagine is a very very common situation. If anyone can point me to a Post already explaining how to do this, I will be very thankful.

Also, I want to code as good as you guy folks do. Are there particularly good courses, video series, or books for me to invest in?

SITUATION: A database is dumped into Excel, a single worksheet with many columns/fields and several thousand rows in the source. I have scrubbed the Source data--eliminated bad data such as misspellings, multiple names in a single field. I'm confident I have good Source data now.
  • Row 1 has the field names: Name, Address, etc.
  • Column A has the search criteria values: Blue, Green, Red, etc.
Goals:
  1. Search all rows in Source worksheet where values in Column A are equal: all Blue.
  2. Copy those entire rows, and paste the copied rows onto a new worksheet, so all Blues on the first worksheet, all Reds on the next, etc.
  3. Also copy the header row from Source, and insert it to Row 1 of each new worksheet.
  4. Rename the worksheets with the values from Column A: "Sheet2" changes to "Blue" etc.
  5. Repeat all the way through the file.
That's it.

It'll be a gigantic workbook with hundreds of sheets, likely to be unwieldy to work with but that's what my buddy asked for.

Thanks very much for the consideration!
 

Excel Facts

Using Function Arguments with nested formulas
If writing INDEX in Func. Arguments, type MATCH(. Use the mouse to click inside MATCH in the formula bar. Dialog switches to MATCH.
Hello Fuzzyizzabear,

This could at least set you in the right direction:-

VBA Code:
Sub CreateNewShtsTransferData()
   
        Dim sht As Worksheet
        Dim lr As Long, i As Long
        Dim ID As Object
        Dim key As Variant

        Set sht = Sheet1 '---->Sheet1 is your main sheet. Here I've used the sheet code not the sheet name.
        Set ID = CreateObject("Scripting.Dictionary")
    
        Application.ScreenUpdating = False
        Application.DisplayAlerts = False
    
        lr = sht.Range("A" & Rows.Count).End(xlUp).Row
    
For i = 2 To lr
        If Not ID.Exists(sht.Range("A" & i).Value) Then
        ID.Add sht.Range("A" & i).Value, 1
        End If
Next i

For Each key In ID.keys
        If Not Evaluate("ISREF('" & key & "'!A1)") Then
        Worksheets.Add(After:=Sheets(Sheets.Count)).Name = key
        End If
   
        sht.Range("A1:A" & lr).AutoFilter 1, key
        sht.[A1].CurrentRegion.Copy Sheets(key).[A1]
        Sheets(key).Columns.AutoFit
        sht.[A1].AutoFilter
Next key

sht.Select
Application.DisplayAlerts = True
Application.ScreenUpdating = True
MsgBox "All done!", vbExclamation

End Sub

Test it in a copy of your workbook first.

I hope that this helps.

Cheerio,
vcoolio.
 
Upvote 0

Forum statistics

Threads
1,225,761
Messages
6,186,893
Members
453,383
Latest member
SSXP

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