Macro to copy Table1 to the end of Table2...

obiwilson

New Member
Joined
Jul 25, 2015
Messages
17
I realize this question is similar to what is being asked here and here. However, when I tried to adapt them for my use I ran into several issues.

On worksheet "Free IDs" I have Table1 from A1:J21 with headers, data validation and formulas.
On worksheet "MASTER LIST" I have Table2 with the same headers and no data atm (I removed all the historical data as it was a mess)

There is a button on the bottom of worksheet "FREE IDs" which needs to perform the following:
- copy data from Table1 (minus the header) to the end of Table2.
- clear data from Table1 from B2:J21 but keep data validation, formulas and set background to no fill color.
or
- clear data from Table1 keeping data validation, formulas, set background to no fill and repopulate column A (A2:A21) with sequential numbers carrying on from what was cleared. So the previous A21+1 would be the new A2...

I have managed to do this, kind of, by recording a macro but it is a very ugly (Insert instead of xlup and loosing data validation...) way of doing it:

VBA Code:
Sub CopyToMaster()
'
' CopyToMaster Macro
' copies the free ID table to the master table then resets the IDs.

    Range("A2:J21").Select
    Selection.Copy
    Sheets("MASTER LIST").Select
    Rows("2:2").Select
    Selection.Insert Shift:=xlDown
    Sheets("Free IDs").Select
    Range("A21").Select
    Application.CutCopyMode = False
    Selection.Copy
    Range("A1").Select
    ActiveSheet.Paste
    Application.CutCopyMode = False
    Selection.AutoFill Destination:=Range("A1:A21"), Type:=xlFillSeries
    Range("A1:A21").Select
    Range("A1").Select
    ActiveCell.FormulaR1C1 = "ID"
    Range("A1").Select
    With Selection.Interior
        .Pattern = xlSolid
        .PatternColorIndex = xlAutomatic
        .ThemeColor = xlThemeColorLight2
        .TintAndShade = 0.599993896298105
        .PatternTintAndShade = 0
    End With
    Range("B2:J21").Select
    Select

I know this can be done in an much more elegant way. Any help would be much appreciated.
 

Excel Facts

Lock one reference in a formula
Need 1 part of a formula to always point to the same range? use $ signs: $V$2:$Z$99 will always point to V2:Z99, even after copying
Worksheet "Free IDs" Table1
DICTATION User Name Codes_test.xls
ABCDEFGHIJ
1IDSurnameFirst NameTitlePositionUnitCODEEmail addressUsername Date Created
22731McTesterJohnMrInternENT3388mctester01/01/1990
32732  
42733  
52734  
62735  
72736  
82737  
92738  
102739  
112740  
122741  
132742  
142743  
152744  
162745  
172746  
182747  
192748  
202749  
212730  
Free IDs
Cell Formulas
RangeFormula
G2:G21G2=IF(ISNA(LOOKUP('Free IDs'!F2,'Unit Codes'!A:A,'Unit Codes'!B:B)),"",LOOKUP('Free IDs'!F2,'Unit Codes'!A:A,'Unit Codes'!B:B))
I2:I21I2=LOWER('Unit Codes'!I2)
Named Ranges
NameRefers ToCells
'Unit Codes'!_FilterDatabase='Unit Codes'!$A$1:$B$72G2:G21
Cells with Conditional Formatting
CellConditionCell FormatStop If True
A1:A21Cell ValueduplicatestextYES
Cells with Data Validation
CellAllowCriteria
D2:D21List='Unit Codes'!$D$2:$D$8
E2:E21List='Unit Codes'!$F$2:$F$8
F2:F21List='Unit Codes'!$A$2:$A$72


Worksheet "MASTER LIST" Table2
DICTATION User Name Codes_test.xls
ABCDEFGHIJ
1IDSurnameFirst NameTitlePositionUnitCODEEmail addressUsernameDate Created
2
MASTER LIST
Cells with Conditional Formatting
CellConditionCell FormatStop If True
A1Cell ValueduplicatestextYES
A2:A65536,O:OCell ValueduplicatestextYES
 
Upvote 0
You have only 1 row populated in FreeIds. Does that mean you only want 1 row copied to the Master List ?
And if that is the case does the numbering restart from 2732 and not 2751 (I am assuming the last 2730 s/be 2750) ?
 
Upvote 0
You have only 1 row populated in FreeIds. Does that mean you only want 1 row copied to the Master List ?
And if that is the case does the numbering restart from 2732 and not 2751 (I am assuming the last 2730 s/be 2750) ?
Free IDs will be full when button is pressed (20 rows).
Yes, that should have been 2750 (I noticed after posting) so it would be restarting from 2751.
 
Upvote 0
On a copy of your workbook, give this a try:

VBA Code:
Sub CopyToMaster_v02()

    Dim shtMstr As Worksheet, shtFree As Worksheet
    Dim tblMstr As ListObject, tblFree As ListObject
    Dim mstrNewRow As ListRow
    Dim freeItemNoMax As Long
    Dim freeRng As Range
    
    Set shtMstr = Worksheets("MASTER LIST")
    Set tblMstr = Range("Table2").ListObject
    
    Set shtFree = Worksheets("Free IDs")
    Set tblFree = Range("Table1").ListObject

    Set mstrNewRow = tblMstr.ListRows.Add
    tblFree.DataBodyRange.Copy Destination:=mstrNewRow.Range
    
    freeItemNoMax = WorksheetFunction.Max(tblFree.ListColumns(1).Range)
    tblFree.DataBodyRange.Rows.Delete

    Set freeRng = tblFree.Range.Cells(1).Offset(1)
    freeRng = freeItemNoMax + 1
    freeRng.AutoFill Destination:=freeRng.Resize(21), Type:=xlFillSeries
    
    With tblFree.DataBodyRange.Interior
        .Pattern = xlSolid
        .PatternColorIndex = xlAutomatic
        .ThemeColor = xlThemeColorLight2
        .TintAndShade = 0.599993896298105
        .PatternTintAndShade = 0
    End With

End Sub
 
Upvote 0
On a copy of your workbook, give this a try:

VBA Code:
Sub CopyToMaster_v02()

    Dim shtMstr As Worksheet, shtFree As Worksheet
    Dim tblMstr As ListObject, tblFree As ListObject
    Dim mstrNewRow As ListRow
    Dim freeItemNoMax As Long
    Dim freeRng As Range
   
    Set shtMstr = Worksheets("MASTER LIST")
    Set tblMstr = Range("Table2").ListObject
   
    Set shtFree = Worksheets("Free IDs")
    Set tblFree = Range("Table1").ListObject

    Set mstrNewRow = tblMstr.ListRows.Add
    tblFree.DataBodyRange.Copy Destination:=mstrNewRow.Range
   
    freeItemNoMax = WorksheetFunction.Max(tblFree.ListColumns(1).Range)
    tblFree.DataBodyRange.Rows.Delete

    Set freeRng = tblFree.Range.Cells(1).Offset(1)
    freeRng = freeItemNoMax + 1
    freeRng.AutoFill Destination:=freeRng.Resize(21), Type:=xlFillSeries
   
    With tblFree.DataBodyRange.Interior
        .Pattern = xlSolid
        .PatternColorIndex = xlAutomatic
        .ThemeColor = xlThemeColorLight2
        .TintAndShade = 0.599993896298105
        .PatternTintAndShade = 0
    End With

End Sub
Thanks, it's close. I got this message box and following result:
1674652719834.png

1674652831647.png

1674652859401.png


I'm not worried about the colour, I can sort that out later. The number sequencing on Free IDs Table1 restarted at 1 and the table now extends down to row 22. I sorted the #REF! in username earlier so not sure what's broken there but I can probably work that out.

In MASTER LIST it didn't paste the CODE or USERNAME which cells are a formula, I think I used a special paste previously to get this to work.

Thanks for your help.
 
Upvote 0
I can change the paste to be paste values but is there any chance you can share a copy of your workbook via a sharing platform eg dropbox, google drive etc. There has to be something different in your data to my test data, in terms of the number sequence not working and that it left a blank row on the destination table.
If you sanitise the data just test the macro on the cut down version to make sure the problem is still there so I can see it.
 
Upvote 0
I can change the paste to be paste values but is there any chance you can share a copy of your workbook via a sharing platform eg dropbox, google drive etc. There has to be something different in your data to my test data, in terms of the number sequence not working and that it left a blank row on the destination table.
If you sanitise the data just test the macro on the cut down version to make sure the problem is still there so I can see it.
I just sent you a DM with a link. Thanks.
 
Upvote 0
OK - please confirm if you are ok to do (1) manually and if you want me to change to paste values (item 4 below)
1) Column 1 in both tables (Column A) is formatted as TEXT
This is preventing the Max function from working.
I can handle it in code but its a OneOff so you are better off doing it manually once.
• Select Column A in the table > Change the format to General
• Goto Text to Tables > Delimited > Finish

2) "Insert Rows" Warning dialogue box
I will handle this in the code

3) Additional Blank when Master Table is empty
I will handle this in the code
Note: the best way to clear the table is to select all rows in the databody range and hit delete. This avoids the extra blank row issue
It looks like you have deleted all rows except row 1 and just cleared content on row 1

4) #REF issue
At the moment the code is doing a straight copy paste. This is not creating the REF issue since it already exists in FreeIDs.
However if you don't want the formulas in the Master, I can change the code to PasteSpecial values.
 
Upvote 0
OK - please confirm if you are ok to do (1) manually and if you want me to change to paste values (item 4 below)
1) Column 1 in both tables (Column A) is formatted as TEXT
This is preventing the Max function from working.
I can handle it in code but its a OneOff so you are better off doing it manually once.
• Select Column A in the table > Change the format to General
• Goto Text to Tables > Delimited > Finish

2) "Insert Rows" Warning dialogue box
I will handle this in the code

3) Additional Blank when Master Table is empty
I will handle this in the code
Note: the best way to clear the table is to select all rows in the databody range and hit delete. This avoids the extra blank row issue
It looks like you have deleted all rows except row 1 and just cleared content on row 1

4) #REF issue
At the moment the code is doing a straight copy paste. This is not creating the REF issue since it already exists in FreeIDs.
However if you don't want the formulas in the Master, I can change the code to PasteSpecial values.
1) Yes, I have just done this. Just confirming it was Text to Column?
2) Thanks.
3) My bad. Worst still, I did that intentionally thinking it might help...
4) Yes, change to PasteSpecial as the formulas will return a different value once Table1 is repopulated with data.

Thanks.
 
Upvote 0

Forum statistics

Threads
1,225,726
Messages
6,186,669
Members
453,368
Latest member
xxtanka

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