Checking existence of sheets and hiding / un-hiding based on cell values










1















I am very much an amateur at this!! Currently I have a worksheet which will have a list of users going down and then a list of sheet names / numbers going across



The overall expectation is that if the user has a 1 in the cell under the sheet then the sheet is visible, otherwise the sheet should be very hidden



This code is in module 1 although not sure if it should be at workbook level instead.



I declare the following outside of the functions so they can be called within each;



Dim lRow As Long, wsStatus As Boolean, shtloc As Integer


Then this is my main function (which maybe should be a sub at workbook level, not sure)



 Function CheckSheetPermission()

Sheet9.Visible = xlSheetVisible
For Each ws In ActiveWorkbook.Worksheets
If ws.Name <> "Welcome" Then ws.Visible = xlSheetVeryHidden
Next ws
Sheet12.Visible = xlSheetVisible
Sheet12.Activate
With ActiveSheet
Dim sht As Worksheet
Call GetRowNum(Range("A3:A200"), LCase(Environ("UserName")))
For Each Cell In Range("B" & lRow & ":GS" & lRow)
If Abs(Cell.Value) = "1" Then
shtloc = Cell(2, ActiveCell.Column).Value
Call wsExists(Sheets(shtloc))
If wsStatus = False Then
Sheets(shtloc).Visible = xlSheetVisible
End If
Else
shtloc = Cell(2, ActiveCell.Column).Value
Call wsExists(Sheets(shtloc))
If wsStatus = False Then
Sheets(shtloc).Visible = xlSheetVeryHidden
End If
End If
Next
End With
End Function


This looks at the sheet below, it is initially meant to make sure both welcome and sheet 1 are temp visible until the code has executed which then sets the correct visibility for all sheets (I assume the sheet has to be visible for the code to read the cells)



image of worksheet





Get row number simply looks up the user and gets the row number



Call GetRowNum(Range("A3:A200"), LCase(Environ("UserName")))


And that function code is



Function GetRowNum(rng As Range, user As String)


On Error Resume Next
lRow = Application.WorksheetFunction.Match(user, rng, 0) + 2
On Error GoTo 0


End Function


Where it seems to be going wrong currently is when I call the next function;



Call wsExists(Sheets(shtloc))


I get the subscript out of range error. Which might be because of the variable before not being set properly or the function itself I am calling but I am not sure where best to start amending code and checking results to further isolate the issue



Limited error handling at this stage as trying to trap errors. if I add error handling to the main function it just passes through and no sheets are hidden or visible other than those set at the start (sheet control and welcome)



Function wsExists(wsSheet As Worksheet)
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsStatus = "True"
Else
wsStatus = "False"
End If

End Function


Please let me know if you need more information.



Simply what I am trying to achieve is the following steps;



  1. Check which sheets should be visible to the user opening the file through a loop

  2. Loop through each of the sheet numbers if they exist using the sheet number variable in conjunction with the 0/1 value under the row next to the user name and set sheet visibility(1 = allowed.0 = not allowed)

I will admit that perhaps this may be a lot better scripted for those who have better understanding



###EDIT

Final code after suggested improvements and some additional changes after I found some extra bugs



Thisworkbook



Private Sub Workbook_Open()

Dim ws As Worksheet
Dim shtloc As String
Dim c As Long
Dim lRow2 As Long
Sheet9.Visible = xlSheetVisible

For Each ws In ActiveWorkbook.Worksheets
If ws.Name <> "Welcome" Then ws.Visible = xlSheetVeryHidden
Next ws
Sheet12.Visible = xlSheetVisible
Sheet12.Activate
With Sheet12
lRow2 = Module2.lRow2(Range("A3:A5"), LCase(Environ("UserName")))


For c = 2 To ActiveWorkbook.Worksheets.Count + 1
shtloc = Cells(1, c).Value2
With Cells(lRow2, c)
perm = Cells(lRow2, c).Value2
Select Case perm
Case ("V")
'Visible
Sheets(shtloc).Visible = xlSheetVisible
Case ("P")
'visible protected
Sheets(shtloc).Visible = xlSheetVeryHidden
Sheets(shtloc).Protect Password:="*********"
Case ("D")
'Access denied
Sheets(shtloc).Visible = xlSheetVeryHidden
End Select
End With
Next c

End With

End Sub


Module



Function lRow2(rng As Range, user As String)

On Error Resume Next
With ActiveSheet
lRow2 = Application.WorksheetFunction.Match(user, rng, 0)

lRow2 = lRow2 + 2

End With
End Function


I no longer check if the sheets exist either as I do a count of sheets and don't carry on the next loop to the blank cells which await new sheet creations to be populated...speeding up the code as well










share|improve this question
























  • You may want to take a look at the different answers here

    – cybernetic.nomad
    Nov 14 '18 at 13:33
















1















I am very much an amateur at this!! Currently I have a worksheet which will have a list of users going down and then a list of sheet names / numbers going across



The overall expectation is that if the user has a 1 in the cell under the sheet then the sheet is visible, otherwise the sheet should be very hidden



This code is in module 1 although not sure if it should be at workbook level instead.



I declare the following outside of the functions so they can be called within each;



Dim lRow As Long, wsStatus As Boolean, shtloc As Integer


Then this is my main function (which maybe should be a sub at workbook level, not sure)



 Function CheckSheetPermission()

Sheet9.Visible = xlSheetVisible
For Each ws In ActiveWorkbook.Worksheets
If ws.Name <> "Welcome" Then ws.Visible = xlSheetVeryHidden
Next ws
Sheet12.Visible = xlSheetVisible
Sheet12.Activate
With ActiveSheet
Dim sht As Worksheet
Call GetRowNum(Range("A3:A200"), LCase(Environ("UserName")))
For Each Cell In Range("B" & lRow & ":GS" & lRow)
If Abs(Cell.Value) = "1" Then
shtloc = Cell(2, ActiveCell.Column).Value
Call wsExists(Sheets(shtloc))
If wsStatus = False Then
Sheets(shtloc).Visible = xlSheetVisible
End If
Else
shtloc = Cell(2, ActiveCell.Column).Value
Call wsExists(Sheets(shtloc))
If wsStatus = False Then
Sheets(shtloc).Visible = xlSheetVeryHidden
End If
End If
Next
End With
End Function


This looks at the sheet below, it is initially meant to make sure both welcome and sheet 1 are temp visible until the code has executed which then sets the correct visibility for all sheets (I assume the sheet has to be visible for the code to read the cells)



image of worksheet





Get row number simply looks up the user and gets the row number



Call GetRowNum(Range("A3:A200"), LCase(Environ("UserName")))


And that function code is



Function GetRowNum(rng As Range, user As String)


On Error Resume Next
lRow = Application.WorksheetFunction.Match(user, rng, 0) + 2
On Error GoTo 0


End Function


Where it seems to be going wrong currently is when I call the next function;



Call wsExists(Sheets(shtloc))


I get the subscript out of range error. Which might be because of the variable before not being set properly or the function itself I am calling but I am not sure where best to start amending code and checking results to further isolate the issue



Limited error handling at this stage as trying to trap errors. if I add error handling to the main function it just passes through and no sheets are hidden or visible other than those set at the start (sheet control and welcome)



Function wsExists(wsSheet As Worksheet)
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsStatus = "True"
Else
wsStatus = "False"
End If

End Function


Please let me know if you need more information.



Simply what I am trying to achieve is the following steps;



  1. Check which sheets should be visible to the user opening the file through a loop

  2. Loop through each of the sheet numbers if they exist using the sheet number variable in conjunction with the 0/1 value under the row next to the user name and set sheet visibility(1 = allowed.0 = not allowed)

I will admit that perhaps this may be a lot better scripted for those who have better understanding



###EDIT

Final code after suggested improvements and some additional changes after I found some extra bugs



Thisworkbook



Private Sub Workbook_Open()

Dim ws As Worksheet
Dim shtloc As String
Dim c As Long
Dim lRow2 As Long
Sheet9.Visible = xlSheetVisible

For Each ws In ActiveWorkbook.Worksheets
If ws.Name <> "Welcome" Then ws.Visible = xlSheetVeryHidden
Next ws
Sheet12.Visible = xlSheetVisible
Sheet12.Activate
With Sheet12
lRow2 = Module2.lRow2(Range("A3:A5"), LCase(Environ("UserName")))


For c = 2 To ActiveWorkbook.Worksheets.Count + 1
shtloc = Cells(1, c).Value2
With Cells(lRow2, c)
perm = Cells(lRow2, c).Value2
Select Case perm
Case ("V")
'Visible
Sheets(shtloc).Visible = xlSheetVisible
Case ("P")
'visible protected
Sheets(shtloc).Visible = xlSheetVeryHidden
Sheets(shtloc).Protect Password:="*********"
Case ("D")
'Access denied
Sheets(shtloc).Visible = xlSheetVeryHidden
End Select
End With
Next c

End With

End Sub


Module



Function lRow2(rng As Range, user As String)

On Error Resume Next
With ActiveSheet
lRow2 = Application.WorksheetFunction.Match(user, rng, 0)

lRow2 = lRow2 + 2

End With
End Function


I no longer check if the sheets exist either as I do a count of sheets and don't carry on the next loop to the blank cells which await new sheet creations to be populated...speeding up the code as well










share|improve this question
























  • You may want to take a look at the different answers here

    – cybernetic.nomad
    Nov 14 '18 at 13:33














1












1








1








I am very much an amateur at this!! Currently I have a worksheet which will have a list of users going down and then a list of sheet names / numbers going across



The overall expectation is that if the user has a 1 in the cell under the sheet then the sheet is visible, otherwise the sheet should be very hidden



This code is in module 1 although not sure if it should be at workbook level instead.



I declare the following outside of the functions so they can be called within each;



Dim lRow As Long, wsStatus As Boolean, shtloc As Integer


Then this is my main function (which maybe should be a sub at workbook level, not sure)



 Function CheckSheetPermission()

Sheet9.Visible = xlSheetVisible
For Each ws In ActiveWorkbook.Worksheets
If ws.Name <> "Welcome" Then ws.Visible = xlSheetVeryHidden
Next ws
Sheet12.Visible = xlSheetVisible
Sheet12.Activate
With ActiveSheet
Dim sht As Worksheet
Call GetRowNum(Range("A3:A200"), LCase(Environ("UserName")))
For Each Cell In Range("B" & lRow & ":GS" & lRow)
If Abs(Cell.Value) = "1" Then
shtloc = Cell(2, ActiveCell.Column).Value
Call wsExists(Sheets(shtloc))
If wsStatus = False Then
Sheets(shtloc).Visible = xlSheetVisible
End If
Else
shtloc = Cell(2, ActiveCell.Column).Value
Call wsExists(Sheets(shtloc))
If wsStatus = False Then
Sheets(shtloc).Visible = xlSheetVeryHidden
End If
End If
Next
End With
End Function


This looks at the sheet below, it is initially meant to make sure both welcome and sheet 1 are temp visible until the code has executed which then sets the correct visibility for all sheets (I assume the sheet has to be visible for the code to read the cells)



image of worksheet





Get row number simply looks up the user and gets the row number



Call GetRowNum(Range("A3:A200"), LCase(Environ("UserName")))


And that function code is



Function GetRowNum(rng As Range, user As String)


On Error Resume Next
lRow = Application.WorksheetFunction.Match(user, rng, 0) + 2
On Error GoTo 0


End Function


Where it seems to be going wrong currently is when I call the next function;



Call wsExists(Sheets(shtloc))


I get the subscript out of range error. Which might be because of the variable before not being set properly or the function itself I am calling but I am not sure where best to start amending code and checking results to further isolate the issue



Limited error handling at this stage as trying to trap errors. if I add error handling to the main function it just passes through and no sheets are hidden or visible other than those set at the start (sheet control and welcome)



Function wsExists(wsSheet As Worksheet)
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsStatus = "True"
Else
wsStatus = "False"
End If

End Function


Please let me know if you need more information.



Simply what I am trying to achieve is the following steps;



  1. Check which sheets should be visible to the user opening the file through a loop

  2. Loop through each of the sheet numbers if they exist using the sheet number variable in conjunction with the 0/1 value under the row next to the user name and set sheet visibility(1 = allowed.0 = not allowed)

I will admit that perhaps this may be a lot better scripted for those who have better understanding



###EDIT

Final code after suggested improvements and some additional changes after I found some extra bugs



Thisworkbook



Private Sub Workbook_Open()

Dim ws As Worksheet
Dim shtloc As String
Dim c As Long
Dim lRow2 As Long
Sheet9.Visible = xlSheetVisible

For Each ws In ActiveWorkbook.Worksheets
If ws.Name <> "Welcome" Then ws.Visible = xlSheetVeryHidden
Next ws
Sheet12.Visible = xlSheetVisible
Sheet12.Activate
With Sheet12
lRow2 = Module2.lRow2(Range("A3:A5"), LCase(Environ("UserName")))


For c = 2 To ActiveWorkbook.Worksheets.Count + 1
shtloc = Cells(1, c).Value2
With Cells(lRow2, c)
perm = Cells(lRow2, c).Value2
Select Case perm
Case ("V")
'Visible
Sheets(shtloc).Visible = xlSheetVisible
Case ("P")
'visible protected
Sheets(shtloc).Visible = xlSheetVeryHidden
Sheets(shtloc).Protect Password:="*********"
Case ("D")
'Access denied
Sheets(shtloc).Visible = xlSheetVeryHidden
End Select
End With
Next c

End With

End Sub


Module



Function lRow2(rng As Range, user As String)

On Error Resume Next
With ActiveSheet
lRow2 = Application.WorksheetFunction.Match(user, rng, 0)

lRow2 = lRow2 + 2

End With
End Function


I no longer check if the sheets exist either as I do a count of sheets and don't carry on the next loop to the blank cells which await new sheet creations to be populated...speeding up the code as well










share|improve this question
















I am very much an amateur at this!! Currently I have a worksheet which will have a list of users going down and then a list of sheet names / numbers going across



The overall expectation is that if the user has a 1 in the cell under the sheet then the sheet is visible, otherwise the sheet should be very hidden



This code is in module 1 although not sure if it should be at workbook level instead.



I declare the following outside of the functions so they can be called within each;



Dim lRow As Long, wsStatus As Boolean, shtloc As Integer


Then this is my main function (which maybe should be a sub at workbook level, not sure)



 Function CheckSheetPermission()

Sheet9.Visible = xlSheetVisible
For Each ws In ActiveWorkbook.Worksheets
If ws.Name <> "Welcome" Then ws.Visible = xlSheetVeryHidden
Next ws
Sheet12.Visible = xlSheetVisible
Sheet12.Activate
With ActiveSheet
Dim sht As Worksheet
Call GetRowNum(Range("A3:A200"), LCase(Environ("UserName")))
For Each Cell In Range("B" & lRow & ":GS" & lRow)
If Abs(Cell.Value) = "1" Then
shtloc = Cell(2, ActiveCell.Column).Value
Call wsExists(Sheets(shtloc))
If wsStatus = False Then
Sheets(shtloc).Visible = xlSheetVisible
End If
Else
shtloc = Cell(2, ActiveCell.Column).Value
Call wsExists(Sheets(shtloc))
If wsStatus = False Then
Sheets(shtloc).Visible = xlSheetVeryHidden
End If
End If
Next
End With
End Function


This looks at the sheet below, it is initially meant to make sure both welcome and sheet 1 are temp visible until the code has executed which then sets the correct visibility for all sheets (I assume the sheet has to be visible for the code to read the cells)



image of worksheet





Get row number simply looks up the user and gets the row number



Call GetRowNum(Range("A3:A200"), LCase(Environ("UserName")))


And that function code is



Function GetRowNum(rng As Range, user As String)


On Error Resume Next
lRow = Application.WorksheetFunction.Match(user, rng, 0) + 2
On Error GoTo 0


End Function


Where it seems to be going wrong currently is when I call the next function;



Call wsExists(Sheets(shtloc))


I get the subscript out of range error. Which might be because of the variable before not being set properly or the function itself I am calling but I am not sure where best to start amending code and checking results to further isolate the issue



Limited error handling at this stage as trying to trap errors. if I add error handling to the main function it just passes through and no sheets are hidden or visible other than those set at the start (sheet control and welcome)



Function wsExists(wsSheet As Worksheet)
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsStatus = "True"
Else
wsStatus = "False"
End If

End Function


Please let me know if you need more information.



Simply what I am trying to achieve is the following steps;



  1. Check which sheets should be visible to the user opening the file through a loop

  2. Loop through each of the sheet numbers if they exist using the sheet number variable in conjunction with the 0/1 value under the row next to the user name and set sheet visibility(1 = allowed.0 = not allowed)

I will admit that perhaps this may be a lot better scripted for those who have better understanding



###EDIT

Final code after suggested improvements and some additional changes after I found some extra bugs



Thisworkbook



Private Sub Workbook_Open()

Dim ws As Worksheet
Dim shtloc As String
Dim c As Long
Dim lRow2 As Long
Sheet9.Visible = xlSheetVisible

For Each ws In ActiveWorkbook.Worksheets
If ws.Name <> "Welcome" Then ws.Visible = xlSheetVeryHidden
Next ws
Sheet12.Visible = xlSheetVisible
Sheet12.Activate
With Sheet12
lRow2 = Module2.lRow2(Range("A3:A5"), LCase(Environ("UserName")))


For c = 2 To ActiveWorkbook.Worksheets.Count + 1
shtloc = Cells(1, c).Value2
With Cells(lRow2, c)
perm = Cells(lRow2, c).Value2
Select Case perm
Case ("V")
'Visible
Sheets(shtloc).Visible = xlSheetVisible
Case ("P")
'visible protected
Sheets(shtloc).Visible = xlSheetVeryHidden
Sheets(shtloc).Protect Password:="*********"
Case ("D")
'Access denied
Sheets(shtloc).Visible = xlSheetVeryHidden
End Select
End With
Next c

End With

End Sub


Module



Function lRow2(rng As Range, user As String)

On Error Resume Next
With ActiveSheet
lRow2 = Application.WorksheetFunction.Match(user, rng, 0)

lRow2 = lRow2 + 2

End With
End Function


I no longer check if the sheets exist either as I do a count of sheets and don't carry on the next loop to the blank cells which await new sheet creations to be populated...speeding up the code as well







excel vba






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 21 '18 at 13:47







Karl Griffiths

















asked Nov 14 '18 at 13:12









Karl GriffithsKarl Griffiths

127




127












  • You may want to take a look at the different answers here

    – cybernetic.nomad
    Nov 14 '18 at 13:33


















  • You may want to take a look at the different answers here

    – cybernetic.nomad
    Nov 14 '18 at 13:33

















You may want to take a look at the different answers here

– cybernetic.nomad
Nov 14 '18 at 13:33






You may want to take a look at the different answers here

– cybernetic.nomad
Nov 14 '18 at 13:33













1 Answer
1






active

oldest

votes


















0














There are a few errors in your code. One things that I would do to avoid confusion would be to use a different iterator within your for loop. Instead of



For Each Cell In Range("B" & lRow & ":GS" & lRow)


I would use



For Each currentCell In Range("B" & lRow & ":GS" & lRow)


This would avoid the first error that I noted:



shtloc = Cell(2, ActiveCell.Column).Value


This line will not return what you want. First, you need an "s" at the end of "Cell". Second, your sheets names are on row 1, third, your code is not clear on which cell is currently activated, this could return strange behaviours. Try instead to replace it by:



shtloc = Cells(1, currentCell.Column).Value


Now your main error is that you try to check if the sheet exists by triggering an error. This generates your out of range error.



Instead you should use a different function to check if the read sheet name exists or not. This answer provides exactly what you want



https://stackoverflow.com/a/6040454/10645669




Function sheetExists(sheetToFind As String) As Boolean
sheetExists = False
For Each sheet In Worksheets
If sheetToFind = sheet.name Then
sheetExists = True
Exit Function
End If
Next sheet
End Function





On a different note, it seems to me that you are using global variables because you are not properly returning values out of your functions. For instance



Function wsExists(wsSheet As Worksheet)
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsStatus = "True"
Else
wsStatus = "False"
End If

End Function


Can be written:



Function wsExists(wsSheet As Worksheet) as boolean
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsExists = "True"
Else
wsExists = "False"
End If

End Function


This allows you to use the function directly in your code like so:



If wsExists(Sheets(shtloc)) = False Then


No more global variable, and no more use of the keyword call.



Also, as a rule of thumb, if the written code does not return anything, then it should be a "sub". These can be called without the keyword call by just stating the arguments without brackets. Example:



subCalled argument1, argument2, argumentN





share|improve this answer

























  • Thank you for all the feedback, I will certainly take on board all those comments. I will be working back through the code based on the above and will confirm back the results.

    – Karl Griffiths
    Nov 14 '18 at 19:51











  • Hello. I have found another issue whilst looking at your changes. Before I finish them I need to make an additional correction. The sheet number I am referencing was coming from the number and not the name as I wanted to ensure even if it renamed it didnt start falling over. But it is treating it an an index number and not codename which also means if tabs re-ordered permissions would change. Are there any suggestions as to how I use codename in those cells but still show the tab name (for reference) so that users know which sheet is what when setting permissions?

    – Karl Griffiths
    Nov 15 '18 at 8:27











Your Answer






StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53301071%2fchecking-existence-of-sheets-and-hiding-un-hiding-based-on-cell-values%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









0














There are a few errors in your code. One things that I would do to avoid confusion would be to use a different iterator within your for loop. Instead of



For Each Cell In Range("B" & lRow & ":GS" & lRow)


I would use



For Each currentCell In Range("B" & lRow & ":GS" & lRow)


This would avoid the first error that I noted:



shtloc = Cell(2, ActiveCell.Column).Value


This line will not return what you want. First, you need an "s" at the end of "Cell". Second, your sheets names are on row 1, third, your code is not clear on which cell is currently activated, this could return strange behaviours. Try instead to replace it by:



shtloc = Cells(1, currentCell.Column).Value


Now your main error is that you try to check if the sheet exists by triggering an error. This generates your out of range error.



Instead you should use a different function to check if the read sheet name exists or not. This answer provides exactly what you want



https://stackoverflow.com/a/6040454/10645669




Function sheetExists(sheetToFind As String) As Boolean
sheetExists = False
For Each sheet In Worksheets
If sheetToFind = sheet.name Then
sheetExists = True
Exit Function
End If
Next sheet
End Function





On a different note, it seems to me that you are using global variables because you are not properly returning values out of your functions. For instance



Function wsExists(wsSheet As Worksheet)
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsStatus = "True"
Else
wsStatus = "False"
End If

End Function


Can be written:



Function wsExists(wsSheet As Worksheet) as boolean
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsExists = "True"
Else
wsExists = "False"
End If

End Function


This allows you to use the function directly in your code like so:



If wsExists(Sheets(shtloc)) = False Then


No more global variable, and no more use of the keyword call.



Also, as a rule of thumb, if the written code does not return anything, then it should be a "sub". These can be called without the keyword call by just stating the arguments without brackets. Example:



subCalled argument1, argument2, argumentN





share|improve this answer

























  • Thank you for all the feedback, I will certainly take on board all those comments. I will be working back through the code based on the above and will confirm back the results.

    – Karl Griffiths
    Nov 14 '18 at 19:51











  • Hello. I have found another issue whilst looking at your changes. Before I finish them I need to make an additional correction. The sheet number I am referencing was coming from the number and not the name as I wanted to ensure even if it renamed it didnt start falling over. But it is treating it an an index number and not codename which also means if tabs re-ordered permissions would change. Are there any suggestions as to how I use codename in those cells but still show the tab name (for reference) so that users know which sheet is what when setting permissions?

    – Karl Griffiths
    Nov 15 '18 at 8:27
















0














There are a few errors in your code. One things that I would do to avoid confusion would be to use a different iterator within your for loop. Instead of



For Each Cell In Range("B" & lRow & ":GS" & lRow)


I would use



For Each currentCell In Range("B" & lRow & ":GS" & lRow)


This would avoid the first error that I noted:



shtloc = Cell(2, ActiveCell.Column).Value


This line will not return what you want. First, you need an "s" at the end of "Cell". Second, your sheets names are on row 1, third, your code is not clear on which cell is currently activated, this could return strange behaviours. Try instead to replace it by:



shtloc = Cells(1, currentCell.Column).Value


Now your main error is that you try to check if the sheet exists by triggering an error. This generates your out of range error.



Instead you should use a different function to check if the read sheet name exists or not. This answer provides exactly what you want



https://stackoverflow.com/a/6040454/10645669




Function sheetExists(sheetToFind As String) As Boolean
sheetExists = False
For Each sheet In Worksheets
If sheetToFind = sheet.name Then
sheetExists = True
Exit Function
End If
Next sheet
End Function





On a different note, it seems to me that you are using global variables because you are not properly returning values out of your functions. For instance



Function wsExists(wsSheet As Worksheet)
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsStatus = "True"
Else
wsStatus = "False"
End If

End Function


Can be written:



Function wsExists(wsSheet As Worksheet) as boolean
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsExists = "True"
Else
wsExists = "False"
End If

End Function


This allows you to use the function directly in your code like so:



If wsExists(Sheets(shtloc)) = False Then


No more global variable, and no more use of the keyword call.



Also, as a rule of thumb, if the written code does not return anything, then it should be a "sub". These can be called without the keyword call by just stating the arguments without brackets. Example:



subCalled argument1, argument2, argumentN





share|improve this answer

























  • Thank you for all the feedback, I will certainly take on board all those comments. I will be working back through the code based on the above and will confirm back the results.

    – Karl Griffiths
    Nov 14 '18 at 19:51











  • Hello. I have found another issue whilst looking at your changes. Before I finish them I need to make an additional correction. The sheet number I am referencing was coming from the number and not the name as I wanted to ensure even if it renamed it didnt start falling over. But it is treating it an an index number and not codename which also means if tabs re-ordered permissions would change. Are there any suggestions as to how I use codename in those cells but still show the tab name (for reference) so that users know which sheet is what when setting permissions?

    – Karl Griffiths
    Nov 15 '18 at 8:27














0












0








0







There are a few errors in your code. One things that I would do to avoid confusion would be to use a different iterator within your for loop. Instead of



For Each Cell In Range("B" & lRow & ":GS" & lRow)


I would use



For Each currentCell In Range("B" & lRow & ":GS" & lRow)


This would avoid the first error that I noted:



shtloc = Cell(2, ActiveCell.Column).Value


This line will not return what you want. First, you need an "s" at the end of "Cell". Second, your sheets names are on row 1, third, your code is not clear on which cell is currently activated, this could return strange behaviours. Try instead to replace it by:



shtloc = Cells(1, currentCell.Column).Value


Now your main error is that you try to check if the sheet exists by triggering an error. This generates your out of range error.



Instead you should use a different function to check if the read sheet name exists or not. This answer provides exactly what you want



https://stackoverflow.com/a/6040454/10645669




Function sheetExists(sheetToFind As String) As Boolean
sheetExists = False
For Each sheet In Worksheets
If sheetToFind = sheet.name Then
sheetExists = True
Exit Function
End If
Next sheet
End Function





On a different note, it seems to me that you are using global variables because you are not properly returning values out of your functions. For instance



Function wsExists(wsSheet As Worksheet)
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsStatus = "True"
Else
wsStatus = "False"
End If

End Function


Can be written:



Function wsExists(wsSheet As Worksheet) as boolean
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsExists = "True"
Else
wsExists = "False"
End If

End Function


This allows you to use the function directly in your code like so:



If wsExists(Sheets(shtloc)) = False Then


No more global variable, and no more use of the keyword call.



Also, as a rule of thumb, if the written code does not return anything, then it should be a "sub". These can be called without the keyword call by just stating the arguments without brackets. Example:



subCalled argument1, argument2, argumentN





share|improve this answer















There are a few errors in your code. One things that I would do to avoid confusion would be to use a different iterator within your for loop. Instead of



For Each Cell In Range("B" & lRow & ":GS" & lRow)


I would use



For Each currentCell In Range("B" & lRow & ":GS" & lRow)


This would avoid the first error that I noted:



shtloc = Cell(2, ActiveCell.Column).Value


This line will not return what you want. First, you need an "s" at the end of "Cell". Second, your sheets names are on row 1, third, your code is not clear on which cell is currently activated, this could return strange behaviours. Try instead to replace it by:



shtloc = Cells(1, currentCell.Column).Value


Now your main error is that you try to check if the sheet exists by triggering an error. This generates your out of range error.



Instead you should use a different function to check if the read sheet name exists or not. This answer provides exactly what you want



https://stackoverflow.com/a/6040454/10645669




Function sheetExists(sheetToFind As String) As Boolean
sheetExists = False
For Each sheet In Worksheets
If sheetToFind = sheet.name Then
sheetExists = True
Exit Function
End If
Next sheet
End Function





On a different note, it seems to me that you are using global variables because you are not properly returning values out of your functions. For instance



Function wsExists(wsSheet As Worksheet)
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsStatus = "True"
Else
wsStatus = "False"
End If

End Function


Can be written:



Function wsExists(wsSheet As Worksheet) as boolean
On Error Resume Next
On Error GoTo 0
If Not wsSheet Is Nothing Then
wsExists = "True"
Else
wsExists = "False"
End If

End Function


This allows you to use the function directly in your code like so:



If wsExists(Sheets(shtloc)) = False Then


No more global variable, and no more use of the keyword call.



Also, as a rule of thumb, if the written code does not return anything, then it should be a "sub". These can be called without the keyword call by just stating the arguments without brackets. Example:



subCalled argument1, argument2, argumentN






share|improve this answer














share|improve this answer



share|improve this answer








edited Nov 14 '18 at 15:27

























answered Nov 14 '18 at 15:20









GTPVGTPV

1445




1445












  • Thank you for all the feedback, I will certainly take on board all those comments. I will be working back through the code based on the above and will confirm back the results.

    – Karl Griffiths
    Nov 14 '18 at 19:51











  • Hello. I have found another issue whilst looking at your changes. Before I finish them I need to make an additional correction. The sheet number I am referencing was coming from the number and not the name as I wanted to ensure even if it renamed it didnt start falling over. But it is treating it an an index number and not codename which also means if tabs re-ordered permissions would change. Are there any suggestions as to how I use codename in those cells but still show the tab name (for reference) so that users know which sheet is what when setting permissions?

    – Karl Griffiths
    Nov 15 '18 at 8:27


















  • Thank you for all the feedback, I will certainly take on board all those comments. I will be working back through the code based on the above and will confirm back the results.

    – Karl Griffiths
    Nov 14 '18 at 19:51











  • Hello. I have found another issue whilst looking at your changes. Before I finish them I need to make an additional correction. The sheet number I am referencing was coming from the number and not the name as I wanted to ensure even if it renamed it didnt start falling over. But it is treating it an an index number and not codename which also means if tabs re-ordered permissions would change. Are there any suggestions as to how I use codename in those cells but still show the tab name (for reference) so that users know which sheet is what when setting permissions?

    – Karl Griffiths
    Nov 15 '18 at 8:27

















Thank you for all the feedback, I will certainly take on board all those comments. I will be working back through the code based on the above and will confirm back the results.

– Karl Griffiths
Nov 14 '18 at 19:51





Thank you for all the feedback, I will certainly take on board all those comments. I will be working back through the code based on the above and will confirm back the results.

– Karl Griffiths
Nov 14 '18 at 19:51













Hello. I have found another issue whilst looking at your changes. Before I finish them I need to make an additional correction. The sheet number I am referencing was coming from the number and not the name as I wanted to ensure even if it renamed it didnt start falling over. But it is treating it an an index number and not codename which also means if tabs re-ordered permissions would change. Are there any suggestions as to how I use codename in those cells but still show the tab name (for reference) so that users know which sheet is what when setting permissions?

– Karl Griffiths
Nov 15 '18 at 8:27






Hello. I have found another issue whilst looking at your changes. Before I finish them I need to make an additional correction. The sheet number I am referencing was coming from the number and not the name as I wanted to ensure even if it renamed it didnt start falling over. But it is treating it an an index number and not codename which also means if tabs re-ordered permissions would change. Are there any suggestions as to how I use codename in those cells but still show the tab name (for reference) so that users know which sheet is what when setting permissions?

– Karl Griffiths
Nov 15 '18 at 8:27




















draft saved

draft discarded
















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53301071%2fchecking-existence-of-sheets-and-hiding-un-hiding-based-on-cell-values%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







這個網誌中的熱門文章

Barbados

How to read a connectionString WITH PROVIDER in .NET Core?

Node.js Script on GitHub Pages or Amazon S3