how to check if a sheet exist?

jamiguel77

Active Member
Joined
Feb 14, 2006
Messages
387
Office Version
  1. 2016
  2. 2010
  3. 2007
Platform
  1. Windows
  2. Web
hi, i know how to:

Dim WorksheetExists As Boolean
WorksheetExists = Evaluate("ISREF('Graficas'!A1)")
and work

But i am work with some workbooks....
and then i need evaluate if exist sheets on each workbook.

this:

WorksheetExists = Evaluate("ISREF('Graficas'!A1)")

Evaluate in the last opened Xls File...


here more code:


Dim wbk As Workbook
Dim wbk2 As Workbook

Set wbk2 = Workbooks.Open(Filename:=Filename2)
Set wbk = Workbooks.Open(Filename:=Filename1)


how to check if sheet named: 'Graficas' exist on wbk2 and wbk?


Thanks
 

Excel Facts

Waterfall charts in Excel?
Office 365 customers have access to Waterfall charts since late 2016. They were added to Excel 2019.
Hi jamiguel77,

Here's a custom function (UDF) that you can run to check if a sheet tab exists within an open workbook of the same Excel session the code is being run in:

Code:
Sub Macro3()

    Dim wbk As Workbook
    Dim wbk2 As Workbook
    
    Set wbk = Workbooks.Open(Filename:=Filename1)
    Set wbk2 = Workbooks.Open(Filename:=Filename2)
    
    If WorkSheetExists(wbk.Name, "Graficas") = False Then 'Just change the workbook and sheet names to run the function each time
        MsgBox "Sheet tab doesn't exist"
    Else
        MsgBox "Sheet tab does exist"
    End If
    
End Sub
'User Defined Function (UDF) to determine if a particular sheet
'exists in a specified workbook.
'Note the specified workbook must be open in the same Excel session the code is being run in.
Function WorkSheetExists(strWBName As String, strWSName As String) As Boolean

    Dim wbk As Workbook
    Dim ws  As Worksheet

    If Len(Trim(strWBName)) = 0 Or Len(Trim(strWSName)) = 0 Then
        WorkSheetExists = Empty
        Exit Function
    End If
    
    'If the 'strWBName' doesn't exist (open) in the current Excel session, then...
    On Error Resume Next
        Set wbk = Workbooks(strWBName)
        If Err.Number <> 0 Then
            '...set the 'WorkSheetExists' and quit
            WorkSheetExists = Empty
            Exit Function
        End If
    On Error GoTo 0
    
    On Error Resume Next
        Set ws = wbk.Sheets(strWSName)
        If Err.Number <> 0 Then
            WorkSheetExists = False
        Else
            WorkSheetExists = True
        End If
    On Error GoTo 0

End Function

Regards,

Robert
 
Upvote 0
Code:
Function WorkSheetExists(WB As Workbook, SheetName As String) As Boolean
    Dim WS As Worksheet, Found As Boolean

    For Each WS In WB.Worksheets
        Found = (WS.Name = SheetName)
        If Found Then Exit For
    Next WS

    WorkSheetExists = Found
End Function
 
Upvote 0

Forum statistics

Threads
1,225,738
Messages
6,186,734
Members
453,369
Latest member
juliewar

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