VBA Code
Sections
Paragraphs
Sentences
Words
Characters
When modifying text it is not necessary to select the text before modifying it
activedocument.content.paragraphformat.space 2
Dim objParagraph As Paragraph
Set objParagraph = ActiveDocument.Paragraphs(2)
objParagraph.Alignment = wdParagraphAlignment.wdAlignParagraphLeft
Dim objRange As Range
Set objRange = ActiveDocument.Paragraphs(2).Range
objRange.Font.Bold = True | False
Dim objFont As Font
Set objFont = ActiveDocument.Paragraphs(2).Range.Font
objFont.Bold = True | False
objDocument.EmbedTrueTypeFonts =
These two lines are equivalent
objDocument.Paragraphs(2).CloseUp
objDocument.Paragraphs(2).SpaceBefore = 0
objDocument.Paragraphs(2).SpaceAfter = 0
Dim objParagraphFormat
objParagraphFormat = objParagraph.Format
The Range property returns a Range object that represents the portion of a document that is contained in the paragraph
objRange = objParagraph.Range
objRange.Text = "some text"
objRange.Font.Name = "Arial"
All the properties and methods of the ParagraphFormat object are also properties and methods of the Paragraph object except the Duplicate property.
activedocument.range(start := mydoc.sentances(2).start, end := mydoc.sentances(4).end)
Manipulates the currently selected paragraph
With Selection.Paragraphs(1).Range
.Font.Bold = False
End With
Get the Index number of the current paragraph
Define a range from the start of the document to the end of the first selected paragraph
Msgbox (ActiveDocument.Range(0,Selection.Paragraphs(1).Range.End).Paragraphs.Count)
Selection.Sections(1) or Selection.Tables(1)
Selection.ParagraphFormat.Alignment = wdAlignParagraphCenter
Selection.ParagraphFormat.LeftIndent = InchesToPoints(2)
Selection.ParagraphFormat.RightIndent = InchesToPoints(2)
Looping through all
Sub LoopAll
Dim oCurrentParagraphs As Word.Range
Dim oParagraph As Word.Paragraph
Dim lParagraphNo As Long
Application.Selection.HomeKey Unit:=WdUnits.wdStory, Extend:=WdMovementType.wdMove
Application.Selection.Range.Select
Do Until ((Selection.End = ActiveDocument.Content.End) Or _
(Selection.End = ActiveDocument.Content.End - 1))
Set oParagraph = Selection.Paragraphs(1)
oParagraph.Range.Select
Set oCurrentParagraphs = ActiveDocument.Range(Start:=0, End:=oParagraph.Range.End)
lParagraphNo = oCurrentParagraphs.Paragraphs.Count
If (Paragraph_DisplaysBullet(oParagraph.Range) = True) Then
Debug.Print "Paragraph: " & lParagraphNo & " - has a bullet"
End If
Selection.MoveDown Unit:=WdUnits.wdParagraph, Count:=1, Extend:=WdMovementType.wdMove
Loop
End Sub
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext