VBA: Autofill current selected cell down according to adjacent column. Columns will be dynamic.

CtJester7807

New Member
Joined
Mar 11, 2020
Messages
6
Office Version
  1. 2019
Hi All,

I've been trying to solve this for a few days now. I am relatively new to VBA, and I am running into trouble due to the data in my worksheets being dynamic.

I need to autofill a formula down to the last row of the adjacent column next to it. The problem I'm running into, is I'm not sure what to title my range, as it wont always be column D for example. I'm aware I can just copy my formula to the bottom of the page, but I would like to keep it cleaner than that. I have been using ActiveCell to drive my steps since I can't rely on any hard coded cells.

What do I need to put in my range, so it selects everything below my active cell down to the last cell of the adjacent column (the column to the left). I also know offset will be used here.

The below is what I have so far.

Cells.Find("Average").Select

Selection.EntireColumn.Offset(0, 1).Insert Shift:=xlToLeft

Selection.End(xlUp).Offset(0, 1).Activate

ActiveCell.Value = "ABS"

ActiveCell.Offset(1, 0).Select

ActiveCell.FormulaR1C1 = "=ABS(RC[-1])"

ActiveCell.Range().FillDown

Thank you!
 

Excel Facts

Spell Check in Excel
Press F7 to start spell check in Excel. Be careful, by default, Excel does not check Capitalized Werds (whoops)
Hi & welcome to MrExcel.
Will "Average" always be in a particular row?
 
Upvote 0
Ok try this
Rich (BB code):
Sub CtJester()
   Dim RngAv As Range

   Set RngAv = Range("1:1").Find("Average", , , xlWhole, , , False, , False)
   RngAv.Offset(, 1).EntireColumn.Insert
   RngAv.Offset(, 1).Value = "ABS"
   Range(RngAv.Offset(1, 1), Cells(Rows.Count, RngAv.Column).End(xlUp).Offset(, 1)).FormulaR1C1 = "=abs(rc[-1])"
End Sub
This assumes that Average will be in row 1 if not, change the value in red to suit
 
Upvote 0
Incredible - you just solved what it took me 2 hours to do incorrectly in a matter of minutes

Thank you SO much. I will now try to make sense of your code!
 
Upvote 0
You're welcome & thanks for the feedback
 
Upvote 0
My apologies but I have one more question - While I'm still trying to make sense of how you did this - I realized I need to autosum the new row for which I just pulled the absolute values and put that beneath the last ABS cell. I'm having trouble figuring out how to sum the new data.
 
Upvote 0
How about
VBA Code:
Sub CtJester()
   Dim RngAv As Range
   Dim UsdRws As Long

   Set RngAv = Range("1:1").Find("Average", , , xlWhole, , , False, , False)
   UsdRws = Cells(Rows.Count, RngAv.Column).End(xlUp).Row
   RngAv.Offset(, 1).EntireColumn.Insert
   RngAv.Offset(, 1).Value = "ABS"
   With RngAv.Offset(1, 1).Resize(UsdRws - 1)
      .FormulaR1C1 = "=abs(rc[-1])"
      Cells(UsdRws + 1, RngAv.Column + 1).Formula = "=sum(" & .Address & ")"
   End With
End Sub
 
Upvote 0
Once again, a big thank you.

No way I was going to get that on my own. Looking forward to be able to contribute elsewhere on this site when I can.
 
Upvote 0

Forum statistics

Threads
1,225,811
Messages
6,187,147
Members
453,409
Latest member
BlueIndian

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