VBA Code Terminating 1 Row Too Early

censo

Board Regular
Joined
Dec 25, 2015
Messages
161
Office Version
  1. 2013
Platform
  1. Windows
Hello,

The formulas in the VBA code below work perfectly for what I'm wanting to achieve; however, I notice that it's terminating 1 row before the last line of data. I thought the "offset" might have something to do with it so when I deleted it, it wreaked havoc, haha. I think the "offset" is to not include the header but as you can see in the results, I just need Columns E, F, and H to be shifted down just one row.

The puzzling part (for me anyway), is that Column D is perfect the way it is and uses the same syntax. Why is that?

Code:
Sub A_Today()


Application.ScreenUpdating = False
    
    With Worksheets("ShippingConfirmation").Range("C2").CurrentRegion.Columns("C")
        .Offset(1, 1).Resize(.Rows.Count - 1, 1).FormulaR1C1 = "=TODAY()"
    .Value = .Value
    End With


    With Worksheets("ShippingConfirmation").Range("D2").CurrentRegion.Columns("D")
        .Offset(1, 1).Resize(.Rows.Count - 1, 1).FormulaR1C1 = _
        "=IF(R[1]C7="""","""",IFERROR(LOOKUP(9.99999999999999E+307,SEARCH(""|""&INDEX(CARRIER_TBL,0,1),""|""&R[1]C7),INDEX(CARRIER_TBL,0,2)),""FedEx""))"
    .Value = .Value
    End With


    With Worksheets("ShippingConfirmation").Range("E2").CurrentRegion.Columns("E")
        .Offset(1, 1).Resize(.Rows.Count - 1, 1).FormulaR1C1 = _
        "=IF(RC[-1] = ""Other"",""United Delivery Service"","""")"
    .Value = .Value
    End With


    With Worksheets("ShippingConfirmation").Range("G2").CurrentRegion.Columns("G")
        .Offset(1, 1).Resize(.Rows.Count - 1, 1).FormulaR1C1 = _
        "=IF(RC[-2] = ""United Delivery Service"",""Standard"","""")"
    .Value = .Value
    End With


Application.ScreenUpdating = True
End Sub

Book1
ADEFGH
1order-idship-datecarrier-codecarrier-nametracking-numbership-method
200000000012018-06-26Lasership?1Z9728W90301392248?
300000000022018-06-26Lasership1LS720804299375
400000000032018-06-26OtherUnited Delivery ServiceC11659806347612Standard
500000000042018-06-26WM6280000000924898
ShippingConfirmation
 
Last edited:

Excel Facts

Format cells as time
Select range and press Ctrl+Shift+2 to format cells as time. (Shift 2 is the @ sign).
I presume the issue is the formula, not the code per se. The formula in the second With block refers to R[1]C7 which is looking at the row below the formula cell. I think you need RC7 instead.
 
Last edited:
Upvote 0
I presume the issue is the formula, not the code per se. The formula in the second With block refers to R[1]C7 which is looking at the row below the formula cell. I think you need RC7 instead.

I agree it looks a little off but this is how I derived that formula in VBA form.

I copied all the formulas I needed to Wordpad
I opened up a blank Excel file
I began recording macros
I went to the respective cell for the formula pasted it in and stopped the macro
I repeated these steps for each of my formulas
I then went into the module (ALT+F11) and extracted the VBA version of those formulas

So, following your logic, only one of the columns would show the formulas falling short. If you look at the screenshot I provided all 3 formulas on separate columns fall short (blank on the last row) and those don't exhibit the proposed anomaly you point out.
 
Upvote 0
I agree it looks a little off

It would be pretty easy to verify, by just amending that line and testing. ;)

So, following your logic, only one of the columns would show the formulas falling short

Nope. Column E is the one that refers to the row below the formula row. Columns F and G both refer to column E, so if that's off, both of them will be too.
 
Upvote 0
It would be pretty easy to verify, by just amending that line and testing. ;)

Nope. Column E is the one that refers to the row below the formula row. Columns F and G both refer to column E, so if that's off, both of them will be too.

I am eating crow for dinner with a slice of humble pie for desert. You were 100% correct and it works perfectly now.

In thinking back, what would have caused the error was me pasting in that code in row 1 instead of the correct row 2. The mistake could have easily been made because in the blank Excel worksheet I used to record the macro I did not have the 1st row header and mistakenly recorded the formula in row 1 vs. row 2, thus causing the 1 row deviation that you pointed out in the formula.

That's why you're the MVP and I'm just a squirrel trying to get a nut! haha.

While I have your attention, I just noticed something new that is a concern. There's one tracking ID in particular that contains non-printable characters. The presence of this information can skew the validity of the tracking information report on the server I upload it to. I know that the CLEAN function can help with this.

Using the code structure and setup above, how can I apply the CLEAN function to column G, where data already exists? I don't want the data to go into a new column, rather, simply replace what's already there. Possible?
 
Upvote 0

Forum statistics

Threads
1,224,823
Messages
6,181,184
Members
453,020
Latest member
Mohamed Magdi Tawfiq Emam

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