Inserting & Deleting
TypeText
Inserts the text at the beginning of the current selection.
The selection is turned into an insertion point at the end of the inserted text.
If Options.ReplaceSelection = True then the original selection will be replaced.
Selection.TypeText "some text"
This behaves exactly the same as typing some text at the keyboard.
TypeParagraph
Insert a paragraph mark at the beginning of the current selection.
The selection is turned into an insertion point after the inserted paragraph mark.
If Options.ReplaceSelection = True then the original selection will be replaced.
Selection.TypeParagraph
This behaves exactly the same as pressing the Enter key.
TypeBackspace
Insert a paragraph mark at the beginning of the current selection.
If the selection is an insertion point, delete the character in front of the insertion point.
If something is currently selected then the selection is turned into an insertion point at the beginning of the current selection.
If Options.ReplaceSelection = True then the original selection will be replaced.
Selection.TypeBackspace
InsertBefore
Inserts the specified text before the Range or Selection.
After the text is inserted, the range or selection is expanded to include the new text.
objRange.InsertBefore(Text:="hello world")
If the selection or range is a bookmark, the bookmark is also expanded to include the next text.
You can insert characters such as quotation marks, tab characters, and nonbreaking hyphens by using the Visual Basic Chr function with the InsertBefore method.
You can also use the following Visual Basic constants: vbCr, vbLf, vbCrLf and vbTab.
This example inserts the text "Solutions" (enclosed in quotation marks) before the selection and then collapses the selection.
With Selection
.InsertBefore Chr(34) & "Solutions" & Chr(34) & Chr(32)
.Collapse Direction:=wdCollapseDirection.wdCollapseEnd
End With
This example inserts the text "Introduction" as a separate paragraph at the beginning of the active document.
With ActiveDocument.Content
.InsertParagraphBefore
.InsertBefore "Introduction"
End With
This example inserts all the font names in the FontNames collection into a new document.
Documents.Add
For Each aFont In FontNames
With Selection
.InsertBefore aFont
.Collapse Direction:=wdCollapseDirection.wdCollapseEnd
.TypeParagraph
End With
Next aFont
InsertAfter
Inserts the specified text after the Range or Selection.
After the text is inserted, the range or selection expanded to include the new text.
objRange.InsertAfter(Text:="hello world")
You can insert characters such as quotation marks, tab characters, and nonbreaking hyphens by using the Visual Basic Chr function with the InsertAfter method.
If you use this method with a range or selection that refers to an entire paragraph, the text is inserted after the ending paragraph mark (the text will appear at the beginning of the next paragraph).
To insert text at the end of a paragraph, determine the ending point and subtract 1 from this location (the paragraph mark is one character), as shown in the following example.
This example inserts text at the end of the active document. The Content property returns a Range object.
ActiveDocument.Content.InsertAfter "end of document"
This example inserts text at the end of the selection and then collapses the selection to an insertion point.
With Selection
.InsertAfter "appended text"
.Collapse Direction:=wdCollapseDirection.wdCollapseEnd
End With
This example inserts text from an input box as the second paragraph in the active document.
response = InputBox("Type some text")
With ActiveDocument.Paragraphs(1).Range
.InsertAfter "1." & Chr(9) & response
.InsertParagraphAfter
End With
InsertParagraph
Replaces a Range or Selection with a new paragraph.
After this method has been used, the range or selection is the new paragraph.
objRange.InsertParagraph
If you don't want to replace the range or selection, use the Collapse method before using this method.
The InsertParagraphAfter method inserts a new paragraph following a Range or Selection object
InsertParagraphAfter
InsertParagraphBefore
Insert text at start of document
Set objRange = ActiveDocument.Paragraphs(2).Range
objRange.Collapse Direction:=wdCollapseDirection.wdCollapseStart
objRange.Text = "start of document"
or
Set objRange = ActiveDocument.Range(Start:=0, End:=0)
objRange.Text = "start of document"
or
Set objRange = ActiveDocument.Range
objRange.StartOf Unit:=wdUnits.wdStory, _
Extend:=wdMovementType.wdMove
objRange.Text = "start of document"
Insert text to the end of a document
To insert text at the end of a document, you can collapse the range to the end using wdCollapseEnd
Set objRange = ActiveDocument.Paragraphs(2).Range
objRange.Collapse Direction:=wdCollapseDirection.wdCollapseEnd
objRange.Text = "end of document"
or
Set objRange = ActiveDocument.Range
objRange.EndOf Unit:=wdUnits.wdStory, _
Extend:=wdMovementType.wdMove
objRange.Text = "end of document"
To refer to the insertion point immediately after the tenth character, set the character position to 10.
Set objRange = ActiveDocument.Range(10,0)
Set objRange = ActiveDocument.Range(9,9) ??
The end paragraph mark is actually counted as a character when you use:
ActiveDocument.Characters.Count
In general
iTotalChars = ActiveDocument.Characters.Count
Set objRange = ActiveDocument.Range(iTotalChars - 1, iTotalChars - 1)
To insert text into a document without replacing existing text use a Range or Selection object that represents a single location (i.e. whose start and end points are equal).
This is easily obtained from an existing range, using the Collapse method
objRange.Collapse Direction:=wdCollapseDirection.wdCollapseStart
objSelection.Collapse Direction:=wdCollapseDirection.wdCollapseEnd
Deleting Text
Backspace
Selection.TypeBackspace
Selection.Delete Unit:=wdUnits.wdCharacter, Count:=1
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext