VBA Code


Types of Views

Application.ActiveWindow.View.Type = wdViewType.wdNormalView 

Displays all non printing characters (hidden text, tab marks, space marks, paragraph marks)

objView.ShowAll 

Toggles the display of just headings or Headings and text

objView.ShowAllHeadings = True / False 

Toggles the display of square brackets around each bookmarks

objView.ShowBookmarks = True / False 

objView.ShowDrawings 
objView.ShowFieldCodes
objView.ShowHeading
objView.ShowHiddenText
objView.ShowParagraphs
objView.ShowSpaces
objView.ShowText
objView.ShowTextBoundaries
objView.TableGridlines


Displaying the Ruler

This is equivalent to (View > Ruler).
Returns or sets whether the ruler(s) is displayed in the active window (Print Layout).
ActiveWindow.DisplayRulers = True
If the view is Print Layout and the Display Rulers is true then the DisplayVerticalRulers determiens whether a vertical ruler will be displayed.

If Application.DisplayRulers = False Then 

End If

You cannot display a vertical ruler unless the horizontal ruler is displayed.


Move to a particular page

Selection.GoTo What:=wdGoToPage 
               Which:=wdGoToNext
               Name:="2"


Document Map

This is the vertical area across the left edge of the window that displays an Outline of the document using heading styles
Determines if the document map is visible or not

Application.DocumentMap = True / False 

Returns or sets the width of the document map as a percentage of the width of the window.

Application.DocumentMapPercentWidth = 20 


Get the Column Number of the selection

This only works for selections, not for ranges.

With Dialogs(wdWordDialog.wdDialogFormatColumns) 
   Debug.Print . ColumnNo
End With


Selecting Pages

To select the page the cursor is in

Selection.GoTo What:=wdGoToBookmark, Name:="\page" 


Deleting Pages


'To set a range object to the page the range is currently in:
'Having previously set the MyRange variable to a range somewhere ...
'you can then operate on the page without selecting it, e.g.

Set MyRange = MyRange.GoTo(What:=wdGoToBookmark, Name:="\page") 
MyRange.Delete


'To set a range object to a particular page number:
'you can then operate on the page without selecting it, e.g.

Dim MyRange As Range 
Set MyRange = ActiveDocument.Range(0, 0)
Set MyRange = MyRange.GoTo(What:=wdGoToPage, Name:="4")
Set MyRange = MyRange.GoTo(What:=wdGoToBookmark, Name:="\page")
MyRange.Delete


Inserting Pages




© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext