Reply
 
LinkBack Thread Tools Search this Thread Display Modes
  #1   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 31
Default Hide sheets by cell value

I am making a database in excel in which two types of information is
beeing produced. Yearly figures and year to date figures. Both type's
consist of multiple sheets (more that 20 is normal), with details
about certain markets. By a dropdown menu i would like to have a
selection on seeing only the sheets in producing the yearly figures or
the YTD figures.

I have the following working on one sheet, but I don't want to write
it for each sheet with a different name. I also noticed that when I
change the sheetname the macro quits working.

Dim sh As Worksheet
Set sh = Worksheets("Assumptions")
With Sheets("P&L current")
If sh.Range("Ae1").Value = 2 Then
.Visible = xlSheetVisible
ElseIf sh.Range("Ae1").Value = 1 Then
.Visible = xlSheetHidden
End If

The dropdown menu puts the value 1 or 2 in cell Ae1. is it possible
that a macro looks in every sheet for cell AE1 and hides or unhides it
by the value 1 or 2???

  #2   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 6,953
Default Hide sheets by cell value

To controll the visibility of each worksheet except Assumptions by looking at
cell AE1 of that sheet, use this code:
Sub ControlSheets()
Dim sh as Worksheet
for each sh in worksheets
if sh.Name < "Assumptions" then
If sh.Range("Ae1").Value = 2 Then
.Visible = xlSheetVisible
ElseIf sh.Range("Ae1").Value = 1 Then
.Visible = xlSheetHidden
End If
end if
Next
end Sub

--
Regards,
Tom Ogilvy

"A. Karatas" wrote:

I am making a database in excel in which two types of information is
beeing produced. Yearly figures and year to date figures. Both type's
consist of multiple sheets (more that 20 is normal), with details
about certain markets. By a dropdown menu i would like to have a
selection on seeing only the sheets in producing the yearly figures or
the YTD figures.

I have the following working on one sheet, but I don't want to write
it for each sheet with a different name. I also noticed that when I
change the sheetname the macro quits working.

Dim sh As Worksheet
Set sh = Worksheets("Assumptions")
With Sheets("P&L current")
If sh.Range("Ae1").Value = 2 Then
.Visible = xlSheetVisible
ElseIf sh.Range("Ae1").Value = 1 Then
.Visible = xlSheetHidden
End If

The dropdown menu puts the value 1 or 2 in cell Ae1. is it possible
that a macro looks in every sheet for cell AE1 and hides or unhides it
by the value 1 or 2???


  #3   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 31
Default Hide sheets by cell value

hello Tom,

for the folowwing code i get the following error

.Visible = xlSheetVisible



= invalid or unqualified error????

  #4   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 2,494
Default Hide sheets by cell value

try putting sh before the . visible on the 2 lines where it appears.

--


Gary


"A. Karatas" wrote in message
oups.com...
hello Tom,

for the folowwing code i get the following error

.Visible = xlSheetVisible



= invalid or unqualified error????



  #5   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 6,953
Default Hide sheets by cell value

I copied your code - guess I didn't clean it up enough.

Sub ControlSheets()
Dim sh as Worksheet
for each sh in worksheets
if sh.Name < "Assumptions" then
If sh.Range("Ae1").Value = 2 Then
sh.Visible = xlSheetVisible
ElseIf sh.Range("Ae1").Value = 1 Then
sh.Visible = xlSheetHidden
End If
end if
Next
end Sub

Regards,
Tom Ogilvy

"A. Karatas" wrote:

hello Tom,

for the folowwing code i get the following error

.Visible = xlSheetVisible



= invalid or unqualified error????




  #6   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 31
Default Hide sheets by cell value

On 20 mrt, 15:27, Tom Ogilvy
wrote:
I copied your code - guess I didn't clean it up enough.

Sub ControlSheets()
Dim sh as Worksheet
for each sh in worksheets
if sh.Name < "Assumptions" then
If sh.Range("Ae1").Value = 2 Then
sh.Visible = xlSheetVisible
ElseIf sh.Range("Ae1").Value = 1 Then
sh.Visible = xlSheetHidden
End If
end if
Next
end Sub

Regards,
Tom Ogilvy



"A. Karatas" wrote:
hello Tom,


for the folowwing code i get the following error


.Visible = xlSheetVisible


= invalid or unqualified error????- Tekst uit oorspronkelijk bericht niet weergeven -


- Tekst uit oorspronkelijk bericht weergeven -


Thankx guys, it works great

  #7   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 28
Default Hide sheets by cell value

A. Karatas wrote:

I am making a database in excel in which two types of information is
beeing produced. Yearly figures and year to date figures. Both type's
consist of multiple sheets (more that 20 is normal), with details
about certain markets. By a dropdown menu i would like to have a
selection on seeing only the sheets in producing the yearly figures or
the YTD figures.

I have the following working on one sheet, but I don't want to write
it for each sheet with a different name. I also noticed that when I
change the sheetname the macro quits working.

Dim sh As Worksheet
Set sh = Worksheets("Assumptions")
With Sheets("P&L current")
If sh.Range("Ae1").Value = 2 Then
.Visible = xlSheetVisible
ElseIf sh.Range("Ae1").Value = 1 Then
.Visible = xlSheetHidden
End If

The dropdown menu puts the value 1 or 2 in cell Ae1. is it possible
that a macro looks in every sheet for cell AE1 and hides or unhides it
by the value 1 or 2???


Is there something on each worksheet that defines it as ytd or yearly other
than the "1" or "2" that you manually allocate? Or are you manually
inputting "1" or "2" on every worksheet to determine that?

This will make all the workshseets with 2 in A1 visible and all the
worksheets with 1 in A1 invisible (and will ignore sheets with neither 2
nor 1 in A1):

Sub test()
For Each ws In Worksheets 'looks through the whole collection of worksheets
If ws.Range("A1") = 2 Then
ws.Visible = False
ElseIf ws.Range("A1") = 1 Then
ws.Visible = True
End If
Next ws
End Sub

HTH
--
Damien
  #8   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 31
Default Hide sheets by cell value

On 20 mrt, 15:34, Damien McBain wrote:
A. Karataswrote:
I am making a database in excel in which two types of information is
beeing produced. Yearly figures and year to date figures. Both type's
consist of multiple sheets (more that 20 is normal), with details
about certain markets. By a dropdown menu i would like to have a
selection on seeing only the sheets in producing the yearly figures or
the YTD figures.


I have the following working on one sheet, but I don't want to write
it for each sheet with a different name. I also noticed that when I
change the sheetname the macro quits working.


Dim sh As Worksheet
Set sh = Worksheets("Assumptions")
With Sheets("P&L current")
If sh.Range("Ae1").Value = 2 Then
.Visible = xlSheetVisible
ElseIf sh.Range("Ae1").Value = 1 Then
.Visible = xlSheetHidden
End If


The dropdown menu puts the value 1 or 2 in cell Ae1. is it possible
that a macro looks in every sheet for cell AE1 and hides or unhides it
by the value 1 or 2???


Is there something on each worksheet that defines it as ytd or yearly other
than the "1" or "2" that you manually allocate? Or are you manually
inputting "1" or "2" on every worksheet to determine that?

This will make all the workshseets with 2 in A1 visible and all the
worksheets with 1 in A1 invisible (and will ignore sheets with neither 2
nor 1 in A1):

Sub test()
For Each ws In Worksheets 'looks through the whole collection of worksheets
If ws.Range("A1") = 2 Then
ws.Visible = False
ElseIf ws.Range("A1") = 1 Then
ws.Visible = True
End If
Next ws
End Sub

HTH
--
Damien- Tekst uit oorspronkelijk bericht niet weergeven -

- Tekst uit oorspronkelijk bericht weergeven -


The dropdown box can make 2 selections. Year which is 1 and YTD which
is 2

A formula on the sheets for year figures searches for the value on the
sheet assumption which says = if(assumptions!AE1=2;1;2) and the
figures YTD looks only at AE1.

In this way it is working super

Reply
Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes

Posting Rules

Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On


Similar Threads
Thread Thread Starter Forum Replies Last Post
Macro to hide sheets based upon cell value Joe M. Excel Discussion (Misc queries) 3 January 13th 10 07:05 PM
Hide or unhide sheets based on cell billinr Excel Discussion (Misc queries) 2 July 13th 07 07:42 PM
Hide sheets based on Cell value Mike Milmoe Excel Discussion (Misc queries) 4 January 16th 07 05:57 AM
Hide all sheets but selected sheets - an example [email protected] Excel Programming 1 April 7th 06 06:29 PM
Hide Certain Sheets based on Cell Data Volsfan Excel Programming 2 August 10th 05 02:26 PM


All times are GMT +1. The time now is 09:33 AM.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Copyright ©2004-2025 ExcelBanter.
The comments are property of their posters.
 

About Us

"It's about Microsoft Excel"