views:

508

answers:

4

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?

+1  A: 

Word can be automated using VBA, and has an object model similiar to Excel.

Dim oWord as Word.Application
Set oWord = CreateObject("Word.Application")

Dim oDoc As Word.Document
Set oDoc = GetObject("c:\Temp\doc1.doc")

' Manipulate Document through oDoc
' ...

Set oDoc = Nothing
Set oWord = Nothing

Ref: How to use Automation with Word 2002

List the words contained in a Word document

Mitch Wheat
+1  A: 

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
Otaku
A: 

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

dmaruca
A: 

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

StevenzNPaul