Select Multiple Table columns by header name (vba)

sspatriots

Well-known Member
Joined
Nov 22, 2011
Messages
585
Office Version
  1. 365
Platform
  1. Windows
Can someone please give me an example of how to select random table columns based on header name? I tried using Array, but I don't think that is the right thing to use as they are random. I don't want to reference column numbers or letters. Thanks, SS

What I have below is where I am. I would rather select the range based on the Set Names I have. Also, what I originally used forced me to break it up into two defined Formatted Ranges, 1 & 2.

VBA Code:
Dim ws As Worksheet
Dim tb As ListObject
Dim FormattedRange1 As Range
Dim FormattedRange2 As Range
Dim FormattedRange As Range
Dim My_Range1 As Range
Dim My_Range2 As Range
Dim My_Range3 As Range
Dim My_Range4 As Range
Dim My_Range5 As Range
Dim My_Range6 As Range
Dim My_Range7 As Range

    Application.CutCopyMode = False
    
Set ws = Sheets("Jobs")
Set tb = ws.ListObjects("G2JobList")
Set My_Range1 = Range("G2JobList[[Cab" & Chr(10) & "REQD Date]], G2JobList[[Cab" & Chr(10) & "RCVD Date]]")
Set My_Range2 = Range("G2JobList[[ENT" & Chr(10) & "REQD Date]], G2JobList[[ENT" & Chr(10) & "RCVD Date]]")
Set My_Range3 = Range("G2JobList[[FXTR" & Chr(10) & "REQD Date]], G2JobList[[FXTR" & Chr(10) & "RCVD Date]]")
Set My_Range4 = Range("G2JobList[[CONTR" & Chr(10) & "REQD Date]], G2JobList[[CONTR" & Chr(10) & "RCVD Date]]")
Set My_Range5 = Range("G2JobList[[Door EQPT" & Chr(10) & "REQD Date]], G2JobList[[Door EQPT" & Chr(10) & "RCVD Date]]")
Set My_Range6 = Range("G2JobList[[Wiring" & Chr(10) & "REQD Date]], G2JobList[[Wiring" & Chr(10) & "RCVD Date]]")
Set My_Range7 = Range("G2JobList[[Jack" & Chr(10) & "REQD Date]], G2JobList[[Jack" & Chr(10) & "RCVD Date]]")

''Define Formatted Ranges for Deletion before Re-Formatting (Too many ranges to be defined under just one name)
Set FormattedRange1 = Range("G2JobList[[Cab" & Chr(10) & "REQD Date]], G2JobList[[Cab" & Chr(10) & _
"RCVD Date]], G2JobList[[ENT" & Chr(10) & "REQD Date]], G2JobList[[ENT" & Chr(10) & _
"RCVD Date]], G2JobList[[FXTR" & Chr(10) & "REQD Date]], G2JobList[[FXTR" & Chr(10) & _
"RCVD Date]], G2JobList[[CONTR" & Chr(10) & "REQD Date]], G2JobList[[CONTR" & Chr(10) & _
"RCVD Date]]")

Set FormattedRange2 = Range("G2JobList[[Door EQPT" & Chr(10) & "REQD Date]], G2JobList[[Door EQPT" & Chr(10) & _
"RCVD Date]], G2JobList[[Wiring" & Chr(10) & "REQD Date]], G2JobList[[Wiring" & Chr(10) & _
"RCVD Date]], G2JobList[[Jack" & Chr(10) & "REQD Date]], G2JobList[[Jack" & Chr(10) & _
"RCVD Date]]")
 

Excel Facts

Which lookup functions find a value equal or greater than the lookup value?
MATCH uses -1 to find larger value (lookup table must be sorted ZA). XLOOKUP uses 1 to find values greater and does not need to be sorted.
To select multiple columns base on the headers:
VBA Code:
Sub select_column()

Dim c As Range, x
With Sheets("Sheet1").ListObjects("Table1")

    For Each x In Array("id", "name", "phone") 'headers name
        If c Is Nothing Then
            Set c = .ListColumns(x).Range
        Else
            Set c = Union(c, .ListColumns(x).Range)
        End If
    Next
   
End With

c.Select

End Sub
 
Upvote 0
Solution
Thank you. I will give this a try when I get back in the office on Monday. Steve
 
Upvote 0
OK.
And if you want to select only the data part (without the header) then use DataBodyRange instead of range, like this:
VBA Code:
Sub select_column1()

Dim c As Range, x
With Sheets("Sheet1").ListObjects("Table1")

    For Each x In Array("id", "Name", "phone") 'headers name
        If c Is Nothing Then
            Set c = .ListColumns(x).DataBodyRange
        Else
            Set c = Union(c, .ListColumns(x).DataBodyRange)
        End If
    Next
    
End With

c.Select

End Sub
 
Upvote 0
You're welcome, glad to help & thanks for the feedback.:)
 
Upvote 0

Forum statistics

Threads
1,225,490
Messages
6,185,294
Members
453,285
Latest member
Wullay

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