Paragraphs
Toggling the display of the Paragraph Marks
ActiveWindow.ActivePane.View.ShowAll = Not ActiveWindow.ActivePane.View.ShowAll
Use the Format property to return the ParagraphFormat object for a paragraph or paragraphs.
The ParagraphFormat property returns the ParagraphFormat object for a selection, range, style, Find object, or Replacement object.
wdUndefined and wdToggle
This value cannot be set as a value but might be returned when a Range contains several different types of formatting.
Lets imagine that the first paragraph in a document contains both bold and not bold text.
This code will change all the text to bold when there is a mixture of bold and not bold and toggle the bold when it either all bold or all not bold.
Dim objParagraphFormat as ParagraphFormat
Set objParagraphFormat = Selection.ParagraphFormat
If (objParagraphFormat.Hyphenation = wsConstants.wdUndefined) Then
objParagraphFormat.Hyphenation = True
Else
objParagraphFormat.Hyphenation = wsConstants.wdToggle
End If
ParagraphFormat Object
With Selection.ParagraphFormat
.Alignment = wdParagraphAlignment.wdAlignParagraphLeft
.AutoAdjustRightIndent = True | False 'automatically adjust the right indent for the specified paragraphs if you've specified a set number of characters per line
.BaseLineAlignment = wdBaselineAlignment.wdBaselineAlignAuto 'represents the vertical position of fonts on a line
.CharacterUnitFirstLineIndent = 0
.CharacterUnitLeftIndent = 0
.CharacterUnitRightIndent = 0
.DisableLineHeightGrid = True | False
.FirstLineIndent = CentimetersToPoints(-1) 'positive value for a first-line indent, negative value for a hanging indent
.HangingPunctuation = True | False
.Hyphenation = True | False
.KeepTogether = True | False
.KeepWithNext = True | False
.LeftIndent = CentimetersToPoints(1) 'this value must be in points
.LineSpacing = 12
.LineSpacingRule = wdLineSpacing.wdLineSpaceAtLeast
.LineUnitAfter = 0
.LineUnitBefore = 0
.NoLineNumber = True | False
.OutlineLevel = wdOutlineLevel.wdOutlineLevelBodyText
.PageBreakBefore = True | False
.RightIndent = CentimetersToPoints(0)
.SpaceAfter = CentimetersToPoints(1.5) 'this value must be in points
.SpaceAfterAuto = True | False
.SpaceBefore = CentimetersToPoints(1.5) 'this value must be in points
.SpaceBeforeAuto = True | False
.Style = wdBuiltinStyle.wdStyleHeading1
.TabStops =
.WidowControl = True | False
.WordWrap = True | False
End With
Dim objParagraphFormat2 As ParagraphFormat
Set objParagraphFormat2 = Selection.ParagraphFormat.Duplicate 'returns a read only object
Borders
Dim colBordersCollection As Borders
Set colBordersCollection = Selection.ParagraphFormat.Borders
Selection.ParagraphFormat.Borders = colBordersCollection
Shading
Dim objShading As Shading
Set objShading = Selection.ParagraphFormat.Shading
With Selection.ParagraphFormat.Shading
.BackgroundPatternColor = wdColorBlue
.BackgroundPatternColorIndex =
.ForegroundPatternColor =
.ForegroundPatternColorIndex =
.Texture =
End With
This example sets Formatting Paragraphs for a range that includes the entire contents of MyDoc.doc. Paragraphs in this document are double-spaced and have a custom tab stop at 0.25 inch.
Set myRange = Documents("MyDoc.doc").Content
With myRange.ParagraphFormat
.Space2
.TabStops.Add Position:=InchesToPoints(.25)
End With
With ActiveDocument.Content.Find
.ClearFormatting
.ParagraphFormat.Space2
.Replacement.ClearFormatting
.Replacement.ParagraphFormat.Space15
.Execute FindText:="", _
ReplaceWith:="", _
Replace:=wdReplace.wdReplaceAll
End With
This example modifies the Heading 2 style for the active document. Paragraphs formatted with this style are indented to the first tab stop and double-spaced.
With ActiveDocument.Styles(wdBuiltinStyle.wdStyleHeading2).ParagraphFormat
.TabIndent(1)
.Space2
End With
With Application.ActivePresentation.Slides(2).Shapes(2)
With .TextFrame.TextRange2.ParagraphFormat
.LineRuleWithin = msoTrue
.SpaceWithin = 1.4
.LineRuleBefore = msoTrue
.SpaceBefore = 0.25
.LineRuleAfter = msoTrue
.SpaceAfter = 0.75
End With
End With
ActiveDocument.Paragraphs(3).Format.Alignment = wdParagraphAlignment.wdAlignParagraphCenter
You can use Visual Basic's New keyword to create a new, standalone ParagraphFormat object. The following example creates a ParagraphFormat object, sets some formatting properties for it, and then applies all of its properties to the first paragraph in the active document.
Dim objParagraphFormat As New ParagraphFormat
objParagraphFormat.Alignment = wdParagraphAlignment.wdAlignParagraphCenter
objParagraphFormat.Borders.Enable = True
ActiveDocument.Paragraphs(1).Format = objParagraphFormat
Set objParagraphFormat = ActiveDocument.Paragraphs(1).Format.Duplicate
myDup.LeftIndent = InchesToPoints(1)
Documents.Add
Selection.InsertAfter "This is a new paragraph."
Selection.Paragraphs.Format = objParagraphFormat
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext