Help cleaning up VBA code that copies/pastes rows and sets print areas

cvrband

Board Regular
Joined
Jan 6, 2016
Messages
63
Office Version
  1. 365
Platform
  1. Windows
I have some VBA that I cobbled together over time with other's assistance and would like to make it more streamlined. The code copies formulas and formatting in the last used row and pastes it in the following rows based on user input. The code currently works but seems cumbersome and slow. The array formula in the middle has helped tremendously, but believe that the rest of the code could be combined/streamlined. If possible, I would like the following:
  • Move the copy/paste section for "Sheet 1" into the current array or something similar to that array so that "Sheet 1" does not need to be ".select" (notice that the "Sheet 1" copy/paste uses the 'NoPt' variant while the array section uses the 'NoTs' variant to dictate the number of rows to copy down)
  • If possible make an array formula to set the print areas of the given pages after the copy/paste commands are completed. Again, to keep from having to activate or '.select' each sheet to change the print area. (Some of the sheets in the array section do not get printed and that is why they are not listed in the print area section of the code)
Here is the current code:
Code:
Sub FormulaCopy()
Dim NoPt As Variant
Dim NoTs As Variant
Dim r As Range, Arr
    'Turn off AutoCalculate
    Application.Calculation = xlManual
    'Turn off screen updating
    Application.ScreenUpdating = False


    NoPt = InputBox("Enter number of points required.", "", "")
    NoTs = InputBox("Enter number of tokens required.", "", "")


        Do Until NoPt <> ""
        Loop
    
        Sheets("Sheet 1").Select
            For i = 1 To NoPt
        'Find the last row of equations
                FinalRow = Sheets("Survey Data").Range("A65536").End(xlUp).Row
        'Copy last row of formulas
                Range("A" & FinalRow & ":T" & FinalRow).Copy
        'Select cell of next empy row
                NextRow = Range("A65536").End(xlUp).Row + 1
                Range("A" & NextRow).Select
                'Past row into next empy row
                ActiveSheet.Paste
            Next i
            NewLastRow = ActiveSheet.Range("A65536").End(xlUp).Row
            Range("A1:S" & NewLastRow).Select
            ActiveSheet.PageSetup.PrintArea = ("A1:S" & NewLastRow)
    
    Do Until NoTs <> ""
    Loop


        Arr = Array("Sheet 2", "AD", "Sheet 3", "P", "Sheet 4", "CA", "Sheet 5", "X", "Sheet 6", "M", "Sheet 7", "AZ")
    
        For i = LBound(Arr) To UBound(Arr) Step 2
            With Sheets(Arr(i))
                rr = .Range("A" & Rows.Count).End(xlUp).Row
                Set r = .Range(.Cells(rr, "A"), .Cells(rr, Arr(i + 1)))
                r.Copy .Range(.Cells(r.Row + 1, "A"), .Cells(r.Row + NoTs, Arr(i + 1)))
                Application.CutCopyMode = False
            End With
        Next


        Sheets("Sheet 2").Select
            NewLastRow = ActiveSheet.Range("A65536").End(xlUp).Row
            Range("A1:AD" & NewLastRow).Select
            ActiveSheet.PageSetup.PrintArea = ("A1:AD" & NewLastRow)
            Range("A1").Select
        Sheets("Sheet 3").Select
            NewLastRow = ActiveSheet.Range("A65536").End(xlUp).Row
            Range("A1:P" & NewLastRow).Select
            ActiveSheet.PageSetup.PrintArea = ("A1:P" & NewLastRow)
            Range("A1").Select
    'Unhide Sheet 4
        Sheets("Sheet 4").Visible = True
        Sheets("Sheet 4").Select
            NewLastRow = ActiveSheet.Range("A65536").End(xlUp).Row
            Range("A1:CA" & NewLastRow).Select
            ActiveSheet.PageSetup.PrintArea = ("A1:CA" & NewLastRow)
            Range("A1").Select
        'Hide Sheet 4
        Sheets("Sheet 4").Visible = False
        Sheets("Sheet 7").Select
            NewLastRow = ActiveSheet.Range("A65536").End(xlUp).Row
            Range("A1:AJ" & NewLastRow).Select
            ActiveSheet.PageSetup.PrintArea = ("A1:AJ" & NewLastRow)
            Range("A1").Select
    Application.CutCopyMode = False
    ' Turn on Screen Updating
    Application.ScreenUpdating = True
    ' Turn on AutoCalculate
    MsgBox "Insertion Complete!"
End Sub

Thank you in advance!
 

Excel Facts

Excel motto
Not everything I do at work revolves around Excel. Only the fun parts.
Last Row
A long time ago, sheets had 65,536 rows, but now contain over 1million. Safer to use code that can handle any number of rows.
Code:
Range("A65536").End(xlUp)
Instead use use
Code:
Range([COLOR=#ff0000]"A" & Rows.Count)[/COLOR].End(xlUp)

Avoid selecting
Selecting anything slows things down and there is usually no requirement to select objects in VBA
Code:
        Sheets("Sheet 2").Select
            NewLastRow = ActiveSheet.Range("A65536").End(xlUp).Row
            Range("A1:AD" & NewLastRow).Select
            ActiveSheet.PageSetup.PrintArea = ("A1:AD" & NewLastRow)
            Range("A1").Select
can be replaced with
Code:
        With Sheets("Sheet 2")
            NewLastRow = .Range([COLOR=#ff0000]"A" & Rows.Count[/COLOR]).End(xlUp).Row
            .PageSetup.PrintArea = ("A1:AD" & NewLastRow)
        End With

Avoid repeating code by creating another sub to set print areas
Code:
Private Sub SetPrintArea(aSheet As Worksheet, aRangeString As String)
    Dim NewLastRow As Long
    With aSheet
        NewLastRow = .Range("A" & Rows.Count).End(xlUp).Row
        .PageSetup.PrintArea = (aRangeString & NewLastRow)
    End With
End Sub
... and call like this
Code:
    Call SetPrintArea(Sheets("Sheet 2"), "A1:AD")
    Call SetPrintArea(Sheets("Sheet 3"), "A1:AD")
    Call SetPrintArea(Sheets("Sheet 4"), "A1:CA")
    Call SetPrintArea(Sheets("Sheet 7"), "A1:AJ")
note
- there is no requirement to Unhide and Hide Sheet 4 if it is not being selected
 
Last edited:
Upvote 0
Thank you, Yongle. Your directions and comments were very helpful. I was able to update my code accordingly and everything works great!
 
Upvote 0

Forum statistics

Threads
1,224,828
Messages
6,181,201
Members
453,022
Latest member
RobertV1609

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