Specific columns from auto filter range - VBA

Millsio88

New Member
Joined
May 1, 2020
Messages
11
Office Version
  1. 2016
Platform
  1. Windows
Is there a way to only copy certain columns from an auto filter?



With the below example the active sheet has 8 columns of data G, L, P, R, S, T, W, AB (other columns have been hidden)



When I copy the data, I don’t want to copy column W & AB so that only 6 columns of data will be moved to sheet 1.



I get lost on offset and resize and the answer might be as simple as changing a figure but can’t seem to get it to work. The below code works other than not copying W & AB.



Sub NewCopy()



With ActiveSheet.AutoFilter.Range

.Offset(1, 0).Resize(.Rows.Count - 1).Copy

Sheets(1).Range("B" & Rows.Count).End(xlUp).Offset(1, 0).PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _

:=False, Transpose:=False

End With



End Sub
 

Excel Facts

Remove leading & trailing spaces
Save as CSV to remove all leading and trailing spaces. It is faster than using TRIM().
What columns, including hidden ones form the AutoFilter range? That is, if all columns were unhidden, which columns would contain the AutoFilter drop-down arrows?
 
Upvote 0
Columns go from A - AI however there is code that hides all apart from the 8 states above.
 
Upvote 0
Columns go from A - AI however there is code that hides all apart from the 8 states above.
Thanks. Try this. (Like your code, it does assume at least one row of visible data below the AutoFilter headings or you will get some unwanted results.)

VBA Code:
Sub NewCopy_v2()
  With ActiveSheet.AutoFilter.Range
    .Offset(1, 6).Resize(.Rows.Count - 1, 14).Copy
    Sheets(1).Range("B" & Rows.Count).End(xlUp).Offset(1, 0).PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
    Application.CutCopyMode = False
  End With
End Sub

BTW, When posting vba code in the forum, please use the available code tags. It makes your code much easier to read/debug & copy. My signature block below has more details.
 
Upvote 0
it does assume at least one row of visible data below the AutoFilter headings or you will get some unwanted results
If it might be possible that a filter was applied that resulted in all rows (except heading) being hidden, then you could add this safety check

Rich (BB code):
Sub NewCopy_v3()
  With ActiveSheet.AutoFilter.Range
    If .Columns(7).SpecialCells(xlVisible).Count > 1 Then
      .Offset(1, 6).Resize(.Rows.Count - 1, 14).Copy
      Sheets(1).Range("B" & Rows.Count).End(xlUp).Offset(1, 0).PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
      Application.CutCopyMode = False
    End If
  End With
End Sub
 
Upvote 0
If it might be possible that a filter was applied that resulted in all rows (except heading) being hidden, then you could add this safety check

Rich (BB code):
Sub NewCopy_v3()
  With ActiveSheet.AutoFilter.Range
    If .Columns(7).SpecialCells(xlVisible).Count > 1 Then
      .Offset(1, 6).Resize(.Rows.Count - 1, 14).Copy
      Sheets(1).Range("B" & Rows.Count).End(xlUp).Offset(1, 0).PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
      Application.CutCopyMode = False
    End If
  End With
End Sub
Thanks so much this works perfectly. Will take the feedback on board for the codes tags on my phone and been a while since in Mr Excel.
 
Upvote 0

Forum statistics

Threads
1,224,815
Messages
6,181,135
Members
453,021
Latest member
Justyna P

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