View Single Post
 
Old 10-28-2019, 09:38 PM
gmayor's Avatar
gmayor gmayor is offline Windows 10 Office 2016
Expert
 
Join Date: Aug 2014
Posts: 4,144
gmayor has much to be proud ofgmayor has much to be proud ofgmayor has much to be proud ofgmayor has much to be proud ofgmayor has much to be proud ofgmayor has much to be proud ofgmayor has much to be proud ofgmayor has much to be proud ofgmayor has much to be proud of
Default

It's a bit unpredictable without access to the document, but the following will loop through the paragraphs.

Code:
Sub TabToEndOfLine()

Dim lngWidth As Long, lngLM As Long, lngRM As Long
Dim oRng As Range
Dim oPara As Paragraph

    For Each oPara In ActiveDocument.Paragraphs
        If oPara.Range.Information(wdWithInTable) = False Then
            Set oRng = oPara.Range

            With oRng.Sections(1).PageSetup
                lngLM = .LeftMargin
                lngRM = .RightMargin
                lngWidth = .PageWidth
            End With

            oRng.End = oRng.End - 1
            With oRng.ParagraphFormat.TabStops
                .ClearAll
                .Add Position:=lngWidth - lngLM - lngRM, _
                     Alignment:=wdAlignTabRight, _
                     Leader:=2
            End With
            oRng.Collapse 0
            oRng.Text = Chr(32) & vbTab
        End If
        DoEvents
    Next oPara
lbl_Exit:
    Set oRng = Nothing
    Set oPara = Nothing
    Exit Sub
End Sub
__________________
Graham Mayor - MS MVP (Word) (2002-2019)
Visit my web site for more programming tips and ready made processes www.gmayor.com
Reply With Quote