I have two workbooks - one with a macro and a button to trigger it (wkbk1), and one with data (wkbk2 - it's actually a csv file). The following works just fine when I run it from within wkbk2:
Dim LR As Long
LR = Range("A" & Rows.Count).End(xlUp).Row
'open the csv file and begin formatting the data
'the following line is commented out when running it from within the csv file
'but is un-commented when I run it from the external workbook
'shift column M to the right
Selection.Insert Shift:=xlToRight, CopyOrigin:=xlFormatFromLeftOrAbove
'insert formula into M2
ActiveCell.FormulaR1C1 = "=IF(RC[-1]=0,""No"",""Yes"")"
'paste the formula down column M to the last populated cell
Range("M2").AutoFill Destination:=Range("M2:M" & LR)
'copy header from L1 to M1
'turn off alerts to save over the existing file
Application.DisplayAlerts = False
'save the csv file as an xlsx file
ActiveWorkbook.SaveAs Filename:="F:\Folder\File.xlsx", _
'turn on alerts again
Application.DisplayAlerts = True
'close the workbook
But I need it to run from another workbook (wkbk1). However, it places the formula in M2, copies it to M1, and then moves on to the next step (copying the column header from L1 to M1) without pasting the formula down column M. It appears that LR is based on column A of wkbk1 and not wkbk2. I need LR to be based on column A in wkbk2, the active workbook, not wkbk1.
Any help would be greatly appreciated.
I am using Excel 2010 on Windows 7.