Behrooz Karjoo
Behrooz Karjoo

Reputation: 4292

How can I loop through every letter in MS Word using VBA?

I have about 100 Word documents which include transliteration of foreign names. The author of these documents used a special font called e2 which has about a dozen special transliteration characters (all of which are available in Microsoft Sans Serif font).

I would like to loop through every letter of the document and whenever the .Font = "e2" I would like to loop through the dozen letters (it's easy to guess what they are) and replace them with a Microsoft Sans Serif equivalent. But I can't figure out how you can loop though letters. Is that doable like looping through cells in an Excel spreadsheet?

Upvotes: 4

Views: 10499

Answers (4)

macropod
macropod

Reputation: 13515

Way faster:

Sub Demo()
Application.ScreenUpdating = False
With ActiveDocument.Range
  With .Find
    .ClearFormatting
    .Replacement.ClearFormatting
    .Font.Name = "e2"
    .Replacement.Font.Name = "Microsoft Sans Serif"
    .Forward = True
    .Format = True
    .Wrap = wdFindContinue
    .Execute Replace:=wdReplaceAll
  End With
End With
Application.ScreenUpdating = True
End Sub

Upvotes: 1

Todd Main
Todd Main

Reputation: 29155

This would be one way to do it, but depending on the size of the document, it may take a long time to execute.

Sub ChangeFonts()
Dim doc As Document
Set doc = ActiveDocument

For i = 1 To doc.Range.Characters.Count
    If doc.Range.Characters(i).Font.Name = "e2" Then
        doc.Range.Characters(i).Font.Name = "Microsoft Sans Serif"
    End If
Next

End Sub

Upvotes: 5

StevenzNPaul
StevenzNPaul

Reputation: 188

use the mswords format find & replace. You will save time & large file won't be a concern.

Upvotes: -1

dmaruca
dmaruca

Reputation: 525

You could also save it as docx, open it in a zip file and do a search/replace inside document.xml and fontTable.xml.

Upvotes: 0

Related Questions