VBA Code
With Application.AutoCorrect
.DisplayAutoCorrectOptions = True
.TwoInitialCapitals = True
.CorrectSentenceCap = True
.CapitalizeNamesOfDays = True
.CorrectCapsLock = True
.ReplaceText = True
End With
Highlight any misspelled words, so that unrecognized words stand out prominently on a printout
Sub HighlightMisspelledWords()
Dim oWord As Range
Dim StoryRange As Range
For Each StoryRange In ActiveDocument.StoryRanges
Application.CheckSpelling Word:=StoryRange
For Each oWord In StoryRange.Words
If Not Application.CheckSpelling(Word:=oWord.Text) Then
oWord.HighlightColorIndex = wdColorIndex.wdYellow
End If
Next oWord
Next StoryRange
End Sub
The following macro clears highlighting from all words:
Sub ClearHighlightFromAllWords()
Dim StoryRange As Range
For Each StoryRange In ActiveDocument.StoryRanges
StoryRange.HighlightColorIndex = wdColorIndex.wdNoHighlight
Next StoryRange
End Sub
Application.Options.AutoFormatApplyBulletedLists
Application.Options.AutoFormatApplyFirstIndents
Application.Options.AutoFormatApplyHeadings
Application.Options.AutoFormatApplyLists
Application.Options.AutoFormatApplyOtherParas
Application.Options.AutoFormatAsYouTypeApplyBorders
Application.Options.AutoFormatAsYouTypeApplyBulletedLists
Application.Options.AutoFormatAsYouTypeApplyClosings
Application.Options.AutoFormatAsYouTypeApplyDates
Application.Options.AutoFormatAsYouTypeApplyFirstIndents
Application.Options.AutoFormatAsYouTypeApplyHeadings
Application.Options.AutoFormatAsYouTypeApplyNumberedLists
Application.Options.AutoFormatAsYouTypeApplyTables
Application.Options.AutoFormatAsYouTypeAutoLetterWizard
Application.Options.AutoFormatAsYouTypeDefineStyles
Application.Options.AutoFormatAsYouTypeDeleteAutoSpaces
Application.Options.AutoFormatAsYouTypeFormatListItemBeginning
Application.Options.AutoFormatAsYouTypeInsertClosings
Application.Options.AutoFormatAsYouTypeInsertOvers
Application.Options.AutoFormatAsYouTypeMatchParentheses
Application.Options.AutoFormatAsYouTypeReplaceFarEastDashes
Application.Options.AutoFormatAsYouTypeReplaceFractions
Application.Options.AutoFormatAsYouTypeReplaceHyperlinks
Application.Options.AutoFormatAsYouTypeReplaceOrdinals
Application.Options.AutoFormatAsYouTypeReplacePlainTextEmphasis
Application.Options.AutoFormatAsYouTypeReplaceQuotes
Application.Options.AutoFormatAsYouTypeReplaceSymbols
Application.Options.AutoFormatDeleteAutoSpaces
Application.Options.AutoFormatMatchParentheses
Application.Options.AutoFormatPlainTextWordMail
Application.Options.AutoFormatPreserveStyles
Application.Options.AutoFormatReplaceFarEastDashes
Application.Options.AutoFormatReplaceFractions
Application.Options.AutoFormatReplaceHyperlinks
Application.Options.AutoFormatReplaceOrdinals
Application.Options.AutoFormatReplacePlainTextEmphasis
Application.Options.AutoFormatReplaceQuotes
Application.Options.AutoFormatReplaceSymbols
Begins a spelling and grammar check for the document and displays the spelling and grammar dialog box when an error occurs.
objDocument.CheckGrammar
If objDocument.GrammarChecked = True / False
selection.range.checkspelling
Begins a spell check. Once this has been executed the SpellingChecked property is set to true
Any subsequent calls will not work unless this property has been set to False.
objDocument.CheckSpelling
The SpellingErrors property returns the ProofReadingErrors collection which contains Range objects that identify the words in the document that are considered to be spelling mistakes.
Set objProofReadingErrors = ActiveDocument.SpellingErrors
The ResetIgnoreAll method clears the list of words that were set to be ignored during the previous spell check.
After this method has been executed all previously ignored words are included in the spell check.
Application.ResetIgnoreAll
objDocument.ComputeStatistics wdStatistic.wdStatisticWords, includefootersandendnotes
The word count is displayed
Set myStat = ActiveDocument.ReadabilityStatistics
Msgbox myStat(1).Name & " - " & myStat(1).Value
Toggle the wavy lines
With ActiveDocument
If .ShowGrammaticalErrors = True Then
.ShowSpellingErrors = False
.ShowGrammaticalErrors = False
Else
If
.ShowSpellingErrors = False
.ShowGrammaticalErrors = False
Else
.ShowSpellingErrors = True
.ShowGrammaticalErrors = True
End If
End If
End With
Print Spelling Errors
Performing a spell check can sometimes take a long time so it is advisable to use the status bar.
Public Sub printSpellingErrors
Dim doc As Document
Dim pf As ProofreadingErrors
Dim pe As Range
Dim sName As String
Application.StatusBar = "Checking Spelling. Please wait. Press Ctrl + Break to interrupt>"
Set pf = ActiveDocument.SpellingErrors
sName = ActiveDocument.FullName
'adding a new document, makes the new document the active one
Set doc = Application.Documents.Add
doc.Range.InsertAfter "Spelling errors for document: " & sName & vbCr
doc.Range.InsertAfter "Spelling errors count " & pf.Count & vbCr
'loop through all the spelling mistakes
For Each pe In pf
doc.Range.InsertAfter "Page " & pe.Information(wdActiveEndAdjustedPageNumber) & " / " & pe.Text & vbCr
Next pe
Application.StatusBar = ""
doc.SaveAs "C:\Temp\Name2.doc"
End Sub
Word Property
Returns the word or phrase that was looked up by the thesaurus. Read-only String.
This example returns a list of synonyms for the first meaning of the third word in the active document.
Sub Syn()
Dim mySynObj As Object
Dim SList As Variant
Dim i As Variant
Set mySynObj = ActiveDocument.Words(3).SynonymInfo
SList = mySynObj.SynonymList(1)
For i = 1 To UBound(SList)
MsgBox "A synonym for " & mySynObj.Word _
& " is " & SList(i)
Next i
End Sub
This example checks to make sure that the word or phrase that was looked up isn't empty. If it's not, the example returns a list of synonyms for the first meaning of the word or phrase.
Sub SelectWord()
Dim mySynObj As Object
Dim SList As Variant
Dim i As Variant
Set mySynObj = Selection.Range.SynonymInfo
If mySynObj.Word = "" Then
MsgBox "Please select a word or phrase"
Else
SList = mySynObj.SynonymList(1)
For i = 1 To UBound(SList)
MsgBox "A synonym for " & mySynObj.Word _
& " is " & SList(i)
Next i
End If
End Sub
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrev