VBA find and replace entire cell contents

camspy

New Member
Joined
Jan 7, 2022
Messages
43
Office Version
  1. 2021
  2. 2019
Platform
  1. Windows
Hello,

I am running Excel 2021 and I have a two sheets, here's Sheet1, it contains values of find (col A) and replace (col B), there might be 1k of rows in there:

Book1
AB
1Abigail<a href="https://example.com/abigail.html"><img src="https://example.com/abigail.jpg"> Abigail</a>
2Sophia<a href="https://example.com/sophia.html"><img src="https://example.com/sophia.jpg"> Sophia</a>
3Amelia<a href="https://example.com/amelia.html"><img src="https://example.com/amelia.jpg"> Amelia</a>
4Elizabeth<a href="https://example.com/elizabeth.html"><img src="https://example.com/elizabeth.jpg"> Elizabeth</a>
5Ava<a href="https://example.com/ava.html"><img src="https://example.com/ava.jpg"> Ava</a>
6Isabella<a href="https://example.com/isabella.html"><img src="https://example.com/isabella.jpg"> Isabella</a>
7Gianna<a href="https://example.com/gianna.html"><img src="https://example.com/gianna.jpg"> Gianna</a>
8Harper<a href="https://example.com/harper.html"><img src="https://example.com/harper.jpg"> Harper</a>
9Mila<a href="https://example.com/mila.html"><img src="https://example.com/mila.jpg"> Mila</a>
10Olivia<a href="https://example.com/olivia.html"><img src="https://example.com/olivia.jpg"> Olivia</a>
Sheet1


The cells in col B might get lengthy, like 1k characters long.

Sheet2 contains cells with contents that need get found and replaced using the data from Sheet1:

Book1
ABCD
1AvaIsabellaOliviaSophia
2IsabellaGiannaAbigailAmelia
3GiannaHarperSophiaElizabeth
4HarperMilaAmeliaMila
5MilaOliviaElizabethOlivia
6OliviaAbigailAvaAbigail
7AbigailSophiaIsabellaAva
8SophiaAmeliaGiannaIsabella
9AmeliaElizabethHarperGianna
10ElizabethAvaMilaHarper
Sheet2


There are like like 200 columns and 2k rows in Sheet2.

I was using some 10-year-old VBA code that stopped working in new Excel with long cell values and also it workes slow as heck.

Is it possible that some new VBA solution would work with long cell values (1k characters long) to use find and replace data from Sheet1 to change entire cell contents in Sheet2?
Any help is appreciated.
Thanks in advance.
 
I think I have it, based on the 1st answer here:

but it's a mess right now.
 
Upvote 0

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)
It sounds hopeful :)
However I don't understand how to tweak your VBA with the one from stackoverflow

I think I have it, based on the 1st answer here:

but it's a mess right now.
 
Upvote 0
This seems to work except it doesn't do anything for Abigail. For some reason you've elected to start with row 2 of sheet1 as noted a couple of times, so that's why.
VBA Code:
Sub MatchAndReplace2()
''this code is ignoring row 1 of sheet(3). Why?
Dim i As Long
Dim SearchString As String, ReplaceString As String
Dim SearchRange As Range, SearchResults As Range, rng As Range

Sheets(2).Copy After:=Sheets(2)
For i = 2 To ThisWorkbook.Sheets(1).Cells(1, 1).CurrentRegion.Rows.Count
   SearchString = ThisWorkbook.Sheets(1).Cells(i, 1).Text
   ReplaceString = ThisWorkbook.Sheets(1).Cells(i, 2).Text
   Set SearchRange = Sheets(3).UsedRange
   Set SearchResults = FindAll(SearchRange, ThisWorkbook.Sheets(1).Cells(i, 1).Text)
   If SearchResults Is Nothing Then
      'No match found
   Else
      For Each rng In SearchResults
         rng.Value = ReplaceString
      Next
   End If
Next

End Sub

Function FindAll(rng As Range, What As Variant, Optional LookIn As XlFindLookIn = xlValues, Optional LookAt As XlLookAt = xlWhole, Optional SearchOrder As XlSearchOrder = xlByColumns, Optional SearchDirection As XlSearchDirection = xlNext, Optional MatchCase As Boolean = False, Optional MatchByte As Boolean = False, Optional SearchFormat As Boolean = False) As Range
Dim SearchResult As Range
Dim firstMatch As String
With rng
   Set SearchResult = .Find(What, , LookIn, LookAt, SearchOrder, SearchDirection, MatchCase, MatchByte, SearchFormat)
   If Not SearchResult Is Nothing Then
      firstMatch = SearchResult.Address
      Do
         If FindAll Is Nothing Then
            Set FindAll = SearchResult
         Else
            Set FindAll = Union(FindAll, SearchResult)
         End If
         Set SearchResult = .FindNext(SearchResult)
      Loop While Not SearchResult Is Nothing And SearchResult.Address <> firstMatch
   End If
End With

End Function
 
Upvote 0
Solution
I must admit that it works like it should.
Extremely slow, but it works.

Maybe turning off screen updating would make it work a little faster?

I've read that this would do the trick, I just have no clue where exactly to add it:
VBA Code:
Application.ScreenUpdating = False

This seems to work except it doesn't do anything for Abigail. For some reason you've elected to start with row 2 of sheet1 as noted a couple of times, so that's why.
VBA Code:
Sub MatchAndReplace2()
''this code is ignoring row 1 of sheet(3). Why?
Dim i As Long
Dim SearchString As String, ReplaceString As String
Dim SearchRange As Range, SearchResults As Range, rng As Range

Sheets(2).Copy After:=Sheets(2)
For i = 2 To ThisWorkbook.Sheets(1).Cells(1, 1).CurrentRegion.Rows.Count
   SearchString = ThisWorkbook.Sheets(1).Cells(i, 1).Text
   ReplaceString = ThisWorkbook.Sheets(1).Cells(i, 2).Text
   Set SearchRange = Sheets(3).UsedRange
   Set SearchResults = FindAll(SearchRange, ThisWorkbook.Sheets(1).Cells(i, 1).Text)
   If SearchResults Is Nothing Then
      'No match found
   Else
      For Each rng In SearchResults
         rng.Value = ReplaceString
      Next
   End If
Next

End Sub

Function FindAll(rng As Range, What As Variant, Optional LookIn As XlFindLookIn = xlValues, Optional LookAt As XlLookAt = xlWhole, Optional SearchOrder As XlSearchOrder = xlByColumns, Optional SearchDirection As XlSearchDirection = xlNext, Optional MatchCase As Boolean = False, Optional MatchByte As Boolean = False, Optional SearchFormat As Boolean = False) As Range
Dim SearchResult As Range
Dim firstMatch As String
With rng
   Set SearchResult = .Find(What, , LookIn, LookAt, SearchOrder, SearchDirection, MatchCase, MatchByte, SearchFormat)
   If Not SearchResult Is Nothing Then
      firstMatch = SearchResult.Address
      Do
         If FindAll Is Nothing Then
            Set FindAll = SearchResult
         Else
            Set FindAll = Union(FindAll, SearchResult)
         End If
         Set SearchResult = .FindNext(SearchResult)
      Loop While Not SearchResult Is Nothing And SearchResult.Address <> firstMatch
   End If
End With

End Function
 
Upvote 0
I'm not surprised it's slow for you. After spending hours on the solution I'm not game for trying to use one or more arrays, mainly because arrays are not one of my strongest points. Might not be applicable anyway. However, see what happens with your suggestion: perhaps disable right after this
Sheets(2).Copy After:=Sheets(2)
and enable before this
End Sub
I think I'd use an error handler lest updating get turned off and not back on, but can't look at that now. You could research error handling and see what you think.
 
Upvote 0
It works, thank you very much!

I'm not surprised it's slow for you. After spending hours on the solution I'm not game for trying to use one or more arrays, mainly because arrays are not one of my strongest points. Might not be applicable anyway. However, see what happens with your suggestion: perhaps disable right after this
Sheets(2).Copy After:=Sheets(2)
and enable before this
End Sub
I think I'd use an error handler lest updating get turned off and not back on, but can't look at that now. You could research error handling and see what you think.
 
Upvote 0
So what speed improvement did you get by doing that?
Are you able to mark this one as solved?
 
Upvote 0
Yes, I've marked your last script as solved.

I can't really say how much faster the last tweak with screen updating was, I wasn't tracking the processing time :)

So what speed improvement did you get by doing that?
Are you able to mark this one as solved?
 
Upvote 0

Forum statistics

Threads
1,223,896
Messages
6,175,264
Members
452,627
Latest member
KitkatToby

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