Range selection specific column with End(xlDown)

dwalc

New Member
Joined
Aug 15, 2024
Messages
4
Office Version
  1. 2021
Platform
  1. Windows
Hello, I'm encounter problem with VBA.

i want to select column A:D, H:J, M:P but with End(xlDown)
after that i want to find and replace the specific value in it like true to 1 and false to 0.

Dim AD As Long
Dim HJ As Long
With Sheets("Data")
AD = .Range("A2:D2").End(xlDown).Row
HJ = .Range("H2:J2").End(xlDown).Row
Selection.Replace What:="True", Replacement:="1", LookAt:=xlPart, _
SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
ReplaceFormat:=False, FormulaVersion:=xlReplaceFormula2
End With

any help would be really appreciated
 

Excel Facts

Test for Multiple Conditions in IF?
Use AND(test, test, test, test) or OR(test, test, test, ...) as the logical_test argument of IF.
Try:

VBA Code:
  Dim ad As Long, hj As Long, mp As Long
  
  With Sheets("Data")
     ad = .Range("A2:D2").End(xlDown).Row
    .Range("A2:D" & ad).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
      
    hj = .Range("H2:J2").End(xlDown).Row
    .Range("H2:J" & hj).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
      
    mp = .Range("M2:P2").End(xlDown).Row
    .Range("M2:P" & mp).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
  End With
 
Upvote 1
Solution
i want to select column A:D, H:J, M:P but with End(xlDown)
Are you aware that using xlDown in that way only applies it to the first column in the range ie for A:D last row in column A, for H:J last row in column H ?
(actually its not necessarily the last row its more likely the last non-blank cell from the starting point)
 
Upvote 0
Try:

VBA Code:
  Dim ad As Long, hj As Long, mp As Long
  
  With Sheets("Data")
     ad = .Range("A2:D2").End(xlDown).Row
    .Range("A2:D" & ad).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
      
    hj = .Range("H2:J2").End(xlDown).Row
    .Range("H2:J" & hj).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
      
    mp = .Range("M2:P2").End(xlDown).Row
    .Range("M2:P" & mp).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
  End With

thank you, it's works.


Are you aware that using xlDown in that way only applies it to the first column in the range ie for A:D last row in column A, for H:J last row in column H ?
(actually its not necessarily the last row its more likely the last non-blank cell from the starting point)

yup, i know. i want to select active column and row but have difficulty to write it in vba.
 
Upvote 0
Typically there is a key data column that you can rely on as always being populated and you use that column to work out the Last Row.
Unless you have data underneath the data you are working on using xlUp is more reliable than xlDown,
You then use that Last Row number in the other ranges you are using.

If that is of interest I can give you an example using your ranges.
 
Upvote 0
please so. i would love to have an insight about it if it doesn't trouble you.
 
Upvote 0
Ok using the solution code you have from Dante, see below.
The idea is that typically the data is a rectangle and you have a key column that is always going to be populated or will always have data on the last row of the rectangle.
So you find the last populated row in that column and use that as the last row for all the columns.

Rich (BB code):
Sub ExampleLastRowUsing_xlUp_BasedOnDantesSolution()

  Dim LastRow As Long
  
  With Sheets("Data")
     LastRow = .Range("A" & Rows.Count).End(xlUp).Row
     
    .Range("A2:D" & LastRow).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
      
    .Range("H2:J" & LastRow).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
      
    .Range("M2:P" & LastRow).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
  End With

End Sub
 
Upvote 1
Complementing what Alex comments, and if the last row applies to all ranges, then you can simplify the code in this way:


VBA Code:
Sub ExampleLastRowUsing_xlUp_BasedOnDantesSolution()
  Dim LastRow As Long
  
  With Sheets("Data")
     LastRow = .Range("A" & Rows.Count).End(xlUp).Row
     
    .Range("A2:D" & LastRow & ",H2:J" & LastRow & ",M2:P" & LastRow).Replace What:="True", _
      Replacement:="1", LookAt:=xlPart, SearchOrder:=xlByRows, MatchCase:=False, _
      SearchFormat:=False, ReplaceFormat:=False
      
  End With
End Sub
 
Upvote 1
Ok using the solution code you have from Dante, see below.
The idea is that typically the data is a rectangle and you have a key column that is always going to be populated or will always have data on the last row of the rectangle.
So you find the last populated row in that column and use that as the last row for all the columns.

Rich (BB code):
Sub ExampleLastRowUsing_xlUp_BasedOnDantesSolution()

  Dim LastRow As Long
  
  With Sheets("Data")
     LastRow = .Range("A" & Rows.Count).End(xlUp).Row
     
    .Range("A2:D" & LastRow).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
      
    .Range("H2:J" & LastRow).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
      
    .Range("M2:P" & LastRow).Replace What:="True", Replacement:="1", LookAt:=xlPart, _
      SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
      ReplaceFormat:=False
  End With

End Sub

I need to read it for a few times to understand the code, and the meaning behind it. I think I get it what you mean. it works great too. thank you, really appreciated it. and Dante simplifying it make it neater. thanks both of you.
 
Upvote 0

Forum statistics

Threads
1,225,619
Messages
6,186,049
Members
453,335
Latest member
sfd039

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