Capturing result in cell from formula and Selection.Replace

BAKELOVEMORE

New Member
Joined
Apr 2, 2024
Messages
13
Office Version
  1. 365
Platform
  1. Windows
I have the following Selection.Replace code that I have used in other subs but I cannot figure out how to capture the cell contents from a formula and pass it to Selection.
I have used Range(activeRow,"H").copy and Selection.copy and passing formula to another variable. I have used .text in all kinds of ways and nothing changes to the string when I run the sub.
I also have tried other ways to join the text including Range((activeRow, "E") , (activeRow, "G")).select.
It does not error, I just do not get the replacement. Thanks for any help you can give me. I assume it is easy but I have searched and tried everything I can think of.

VBA Code:
Sub GetStnProbs()
    Application.ScreenUpdating = False

    Const SubName As String = "GetStnProbs"  
    Const SheetName As String = "OBSERVATIONS"     
    If ActiveSheet.Name <> SheetName Then
        MsgBox "This macro can only be called from '" & SheetName & "'", vbOKOnly, SubName
    Exit Sub
    End If
 
    Dim activeRow As Long
    Dim formula As String
    Dim ActiveCell2 As Range
    activeRow = ActiveCell.Row

    formula = "=TEXTJOIN({"" & ""},TRUE,FILTER('STATION LIST'!$E$2:$G$66,'STATION LIST'!$C$2:$C$66 = E" & activeRow & "))"

    ActiveSheet.Cells(activeRow, "H").formula = formula
    ActiveCell = ActiveSheet.Cells(activeRow, "H")
    ActiveCell.Activate
    Set ActiveCell2 = ActiveCell
    Selection.Copy
    Selection.Replace What:="OOF", Replacement:="OUT OF FOCUS ", LookAt:=xlPart, _
    SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
    ReplaceFormat:=False
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
    :=False, Transpose:=False
    Clipboard ActiveCell
    Range("H65").PasteSpecial
    ActiveCell2.Activate
    Application.CutCopyMode = False
    Application.ScreenUpdating = True
 
End Sub
 

Excel Facts

When they said...
When they said you are going to "Excel at life", they meant you "will be doing Excel your whole life".
don't have Excel atm, but does this help
VBA Code:
Sub GetStnProbs()
    Application.ScreenUpdating = False

    Const SubName As String = "GetStnProbs"
    Const SheetName As String = "OBSERVATIONS"
    If ActiveSheet.Name <> SheetName Then
        MsgBox "This macro can only be called from '" & SheetName & "'", vbOKOnly, SubName
    Exit Sub
    End If
 
    Dim activeRow As Long, formula As String, ActiveCell2 As Range
    activeRow = ActiveCell.Row
    ActiveSheet.Cells(activeRow, "H").formula = "=TEXTJOIN({"" & ""},TRUE,FILTER('STATION LIST'!$E$2:$G$66,'STATION LIST'!$C$2:$C$66 = E" & activeRow & "))"
    ActiveCell = ActiveSheet.Cells(activeRow, "H")
    ActiveCell.Replace What:="OOF", Replacement:="OUT OF FOCUS ", LookAt:=xlPart, SearchOrder:=xlByRows
    ActiveCell.PasteSpecial Paste:=xlPasteValues
    Range("H65").Value = ActiveCell.Value
    Application.CutCopyMode = False
    Application.ScreenUpdating = True
 
End Sub
 
Upvote 0
Solution
don't have Excel atm, but does this help
VBA Code:
Sub GetStnProbs()
    Application.ScreenUpdating = False

    Const SubName As String = "GetStnProbs"
    Const SheetName As String = "OBSERVATIONS"
    If ActiveSheet.Name <> SheetName Then
        MsgBox "This macro can only be called from '" & SheetName & "'", vbOKOnly, SubName
    Exit Sub
    End If
 
    Dim activeRow As Long, formula As String, ActiveCell2 As Range
    activeRow = ActiveCell.Row
    ActiveSheet.Cells(activeRow, "H").formula = "=TEXTJOIN({"" & ""},TRUE,FILTER('STATION LIST'!$E$2:$G$66,'STATION LIST'!$C$2:$C$66 = E" & activeRow & "))"
    ActiveCell = ActiveSheet.Cells(activeRow, "H")
    ActiveCell.Replace What:="OOF", Replacement:="OUT OF FOCUS ", LookAt:=xlPart, SearchOrder:=xlByRows
    ActiveCell.PasteSpecial Paste:=xlPasteValues
    Range("H65").Value = ActiveCell.Value
    Application.CutCopyMode = False
    Application.ScreenUpdating = True
 
End Sub
That does exactly what I need and pastes the correct string but I am getting an ERR 1004 PasteSpecial method of Range class failed on the line
VBA Code:
ActiveCell.PasteSpecial Paste:=xlPasteValues
I have tried my old PasteSpecial and
VBA Code:
wk.Worksheets("OBSERVATIONS").Range(activeRow, "H").PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
            :=False, Transpose:=False
 
Upvote 0
Change from
VBA Code:
ActiveCell.PasteSpecial Paste:=xlPasteValues
to
VBA Code:
ActiveCell.value=ActiveCell.value
 
Upvote 0

Forum statistics

Threads
1,225,120
Messages
6,182,964
Members
453,141
Latest member
Owy

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