[Okta Webinar] Learn how to a build a cloud-first strategyRegister Now

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 89
  • Last Modified:

Determine Range to Select

Hi All,

I have the code below which currently selects a fixed range and hides columns where the value of the cell in row 1 is not blank but is zero.
Range("L1:YF1").Select
    Selection.EntireColumn.Hidden = False
    
    For Each Cell In Selection
        Count = Count + 1
    Next Cell
        
    Range("L1").Select
    For Ch = 1 To Count
        If ActiveCell.Value <> "" And ActiveCell.Value = 0 Then
        Selection.EntireColumn.Hidden = True
        Else
        End If
        ActiveCell.Offset(0, 1).Range("$A$1").Select
    Next Ch
Range("$K$2").Select

Open in new window

Question is, line 1 selects a fixed Range but I would like to change this to the equivalent of "Shift + Ctrl + End" ie from current cell to the last cell in the row. End Right won't work because there are gaps.

I could go to XFD1 and then do an End Left to determine the last column but how do I then convert that into the range to be selected.

For the second section of the code where I am using ActiveCell.Offset to move across one column at a time. I assume this is the "right" way to do it because I assume that if I did it with "For Each Cell in Selection.... Next Cell" I would end up hiding the whole selection each time. Happy to be corrected on that point.

As always, much appreciated.
Thanks
Rob H
0
Rob Henson
Asked:
Rob Henson
  • 3
  • 2
1 Solution
 
Patrick MatthewsCommented:
Why bother selecting anything at all?

Dim rng As Range
Dim cel As Range

Set rng = Range(Range("L1"), Cells(1, Columns.Count).End(xlToLeft))
For Each cel In rng.Cells
    If cel <> "" and cel = 0 Then
        cel.EntireColumn.Hidden = True
    End If
Next

Open in new window


Note that by using Columns.Count, this is also compatible with pre-2007 versions of Excel, which were limited to 256 columns.
0
 
Rob HensonIT & Database AssistantAuthor Commented:
That looks great Patrick!!

Do I have to Unhide columns to start with? If a column was previously zero value it would get hidden but if there is now a value in that column I need it unhidden; hence line 2 unhiding the whole range.

There are no other hidden columns so I could select the whole sheet to Unhide if so required.
0
 
Patrick MatthewsCommented:
This may be even better, as it will unhide columns that were already hidden, but did not meet the criteria for being hidden.  The version you choose will depend on your exact need.

Dim rng As Range
Dim cel As Range

Set rng = Range(Range("L1"), Cells(1, Columns.Count).End(xlToLeft))
For Each cel In rng.Cells
    cel.EntireColumn.Hidden = (cel <> "" And cel = 0)
Next

Open in new window

0
 
Patrick MatthewsCommented:
I see our comments crossed paths :)
0
 
Rob HensonIT & Database AssistantAuthor Commented:
Excellent amendment, thank you!!
0

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

  • 3
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now