Inserting / Deleting
ActiveWorkbook
You can insert additional worksheets into the active workbook by adding to its sheets collection:
Application.ActiveWorkbook.Sheets.Add(Before, After, Count, Type)
Since ActiveWorkbook is the default member of the Application object you can also use:
Application.Sheets.Add(Before, After, Count, Type)
Since Application is the default member you could abbreviate it and use:
Sheets.Add(Before, After, Count, Type)
Inserting a Worksheet
To insert a worksheet after the worksheet that is currently selected you can use:
Sheets.Add(Type:=xlSheetType.xlWorksheet)
Because the sheet type xlWorksheet is the default you can shorten this to just:
Sheets.Add
If you are copying or moving worksheets around in a workbook you cannot debug/step through the code.
Whenever referencing workbooks or worksheets always enclose them in single speech marks "WshName" as they could contain spaces and/or unusual characters.
If your VBA code is generating Dr Watsons or Application Errors when trying to select a worksheet, then the workbook may be corrupt. Copy all the worksheets to a new workbook.
To quickly view the event procedure for a worksheet right - click the Sheet tab and click View Code.
If you give your worksheet names using the Property window you can refer directly to the name in code instead of using Sheets("---").
It is not possible to add a chart sheet after the last worksheet in a workbook. You will have to insert it elsewhere and then move it.
Dim oWsh As Excel.Worksheet
Set oWsh = Worksheets.Add
Add a Sheet First
Set oFirst = ThisWorkbook.Worksheets(1)
Set oNew = ThisWorkbook.Worksheets.Add(Before:= oFirst)
Add a Sheet Last
Set oLast = ThisWorkbook.Worksheets(ThisWorkbook.Worksheets.Count)
Set oNew = ThisWorkbook.Worksheets.Add(After:= oLast)
List all worksheets
For icount = 1 To ThisWorkbook.Worksheets.Count
Debug.Print ThisWorkbook.Worksheets(i).Name
Next icount
Deleting Sheets
Public Function BET_WshDelete(sWshName As String)
Application.DisplayAlerts = bDisplayAlerts
Sheets(sWshName).Delete
Application.DisplayAlerts = True
End Sub
The last line is not actually needed as the DisplayAlerts is automatically reset, although it makes your code more readable
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext