Solved

Excel VBA Macro - Find and Replace all based on RegEx

Posted on 2015-02-09
13
410 Views
Last Modified: 2016-02-10
I need to update ALL prices within a PDF based on a percentage.  To start though I will obviously need to be able to successfully find ALL prices first.  Prices are in the format such as:

5.55
12.35
125.55
etc.

I found the below VBA code courtesy from www.TheSpreadsheetGuru.com however, I do not know how to modify it to search ALL worksheets and to search for a pattern/regex.

Sub FindReplaceAll()

'PURPOSE: Find & Replace text/values throughout entire workbook
'SOURCE: www.TheSpreadsheetGuru.com

Dim sht As Worksheet
Dim fnd As Variant
Dim rplc As Variant

fnd = "April"
rplc = "May"

For Each sht In ActiveWorkbook.Worksheets
  sht.Cells.Replace what:=fnd, Replacement:=rplc, _
    LookAt:=xlPart, SearchOrder:=xlByRows, MatchCase:=False, _
    SearchFormat:=False, ReplaceFormat:=False
Next sht

End Sub

Open in new window

0
Comment
Question by:LouSch7
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 7
  • 6
13 Comments
 
LVL 46

Expert Comment

by:aikimark
ID: 40598887
1. Is the data in a workbook or PDF?
2. What does the regular expression have to do with the problem (given the code you posted)?
3. Do you need to limit your changes to cell text or cell value, which may include the result of a formula?
0
 
LVL 3

Author Comment

by:LouSch7
ID: 40601211
Aikimark,

1. The data is in a Workbook

2. Regex is the best way I know how to perform pattern matching; the code posted is simply a stepping stone of how to perform a find and replace within a given worksheet.  I need to expand on that concept and perform a find and replace based on a pattern for the find and a formula for the replace; against the entire workbook.

3. Changes would be limited to cell text, there are no formulas within the workbook at all.
0
 
LVL 46

Expert Comment

by:aikimark
ID: 40601543
so, let's talk about what you perceive to be the pattern of prices.  I know you've given three examples of prices, but I want you to describe what would separate a price numeric value from a non-price numeric value.
0
Online Training Solution

Drastically shorten your training time with WalkMe's advanced online training solution that Guides your trainees to action. Forget about retraining and skyrocket knowledge retention rates.

 
LVL 3

Author Comment

by:LouSch7
ID: 40601630
Akimark,

Solid question.  A price is defined as any number of numeric values, followed by a decimal and two trailing numeric values.  There are no commas and no dollar signs.  There are no other numeric values that match this pattern.

examples:

#####.##
###.##
#.##
0
 
LVL 46

Expert Comment

by:aikimark
ID: 40602144
Will these numeric values be the only contents of the cell or might they be part of a text string in a cell?
0
 
LVL 3

Author Comment

by:LouSch7
ID: 40602204
The cell has no additional text, only the price value.
0
 
LVL 46

Expert Comment

by:aikimark
ID: 40602219
You can do pattern matching without regular expressions:
Sub Q_28613166()
    Dim rngCell As Range
    Dim rngNumbers As Range
    Dim wks As Worksheet
    For Each wks In ActiveWorkbook.Sheets
        Set rngNumbers = wks.Cells.SpecialCells(xlCellTypeConstants, xlNumbers)
        For Each rngCell In rngNumbers
            If rngCell.Value Like "*#.##" Then
                Debug.Print rngCell.Address, rngCell.Value
            End If
        Next
    Next
End Sub

Open in new window

0
 
LVL 3

Author Comment

by:LouSch7
ID: 40602369
Aikmark,

That works beautifully however, apparently some of the "numbers" are actually formatted as text... didn't realize this since it is an 80 tab workbook; your script worked wonders however, it cannot account for values that are not numbers.  Assuming this has to do with the SpecialCells and xlNumbers portion of your script?

Is there a way to look for the pattern within all cells (text as well), the convert (val(rngCell.value) the cell to a number prior to updating it?
0
 
LVL 46

Expert Comment

by:aikimark
ID: 40602403
please post a workbook with representative data
0
 
LVL 3

Author Comment

by:LouSch7
ID: 40602911
Attached is an example with the current macro/vb we are working on.
Update-Price-Excel-Sample.xlsm
0
 
LVL 46

Accepted Solution

by:
aikimark earned 500 total points
ID: 40603019
try this:
Sub Q_28613166()
    Dim rngCell As Range
    Dim rngNumbers As Range
    Dim wks As Worksheet
    Application.ScreenUpdating = False
    For Each wks In ActiveWorkbook.Sheets
        Set rngNumbers = wks.Cells.SpecialCells(xlCellTypeConstants, xlNumbers + xlTextValues)
        For Each rngCell In rngNumbers
            If IsNumeric(rngCell.Value) Then
                If rngCell.Value Like "*#.##" Then
                     rngCell.Value = Format(rngCell.Value * 1.1, "0.00")
                End If
            End If
        Next
    Next
    Application.ScreenUpdating = True
End Sub

Open in new window

0
 
LVL 3

Author Comment

by:LouSch7
ID: 40603463
Aikmark,

That works wonderfully.

Here is the final code I put together

Sub Q_28613166()
    Dim rngCell As Range
    Dim rngNumbers As Range
    Dim wks As Worksheet
    
    Dim perUpdate As Integer
    
    perUpdate = InputBox("What percentage would you like to increase ALL prices by? (1.1 = 10%)")
    
    Application.ScreenUpdating = False
    For Each wks In ActiveWorkbook.Sheets
        Set rngNumbers = wks.Cells.SpecialCells(xlCellTypeConstants, xlNumbers + xlTextValues)
        For Each rngCell In rngNumbers
            If IsNumeric(rngCell.Value) Then
                If rngCell.Value Like "*#.##" Then
                     rngCell.Value = Format(rngCell.Value * perUpdate, "0.00")
                End If
            End If
        Next
    Next
    Application.ScreenUpdating = True
End Sub

Open in new window

0
 
LVL 3

Author Closing Comment

by:LouSch7
ID: 40603468
Aikimark communicated well and provided a 100% solution for the question.
0

Featured Post

Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Describes a method of obtaining an object variable to an already running instance of Microsoft Access so that it can be controlled via automation.
In Part II of this series, I will discuss how to identify all open instances of Excel and enumerate the workbooks, spreadsheets, and named ranges within each of those instances.
Excel styles will make formatting consistent and let you apply and change formatting faster. In this tutorial, you'll learn how to use Excel's built-in styles, how to modify styles, and how to create your own. You'll also learn how to use your custo…
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…

624 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question