Creating Tables
Tables.Add
Dim oTable As Word.Table
Set oTable = ActiveDocument.Tables.Add(Range:=Selection.Range, _
NumRows:=3, _
NumColumns:=4, _
DefaultTableBehavior:=wdDefaultTableBehavior.wdWord8TableBehavior, _
AutoFitBehavior:=wdAutoFitBehavior.wdAutoFitWindow)
oTable.PreferredWidthType = wdPreferredWidthType.wdPreferredWidthPoints
oTable.PreferredWidth = 50
oTable.Rows.VerticalPosition = 0 (single value)
oTable.Rows.Alignment = wdRowAlignment.wdAlignRowLeft
oTable.Rows.HorizontalPosition = 0 (single value)
oTable.Rows.HeightRule = wdRowHeightRule.wdRowHeightAuto
oTable.Rows.RelativeHorizontalPosition = wdRelativeHorizontalPosition.wdRelativeHorizontalPositionPage
oTable.Rows.RelativeVerticalPosition = wdRelativeVerticalPosition.wdRelativeVerticalPositionMargin
Nested Tables
Public Sub InsertNested()
Documents.Add
ActiveDocument.Tables.Add Selection.Range, 3, 3, wdWord9TableBehavior, wdAutoFitContent
With ActiveDocument.Tables(1).Range
.Copy
.Cells(1).Range.Text = .Cells(1).NestingLevel
.Cells(5).Range.PasteAsNestedTable
With .Cells(5).Tables(1).Range
.Cells(1).Range.Text = .Cells(1).NestingLevel
.Cells(5).Range.PasteAsNestedTable
With .Cells(5).Tables(1).Range
.Cells(1).Range.Text = _
.Cells(1).NestingLevel
End With
.Columns(2).Select
Selection.TopLevelTables(1).Select
End With
End With
End Sub
What is the difference between ??
oTable.Style = objstyle
oTable.Range.Style = objstyle
Sub Testing()
Dim oTable As Word.Table
Set oTable = Application.ActiveDocument.Tables.Add(Range:=Application.Selection.Range, NumRows:=1, NumColumns:=1)
Debug.Print objTable.PreferredWidthType
End Sub
Public Sub TestingDis_Insert()
Dim oRange As Word.Range
Dim iNoOfSections As Integer
Dim objTable As Word.Table
Dim sngTableWidthPoints As Single
Application.ActiveDocument.PageSetup.DifferentFirstPageHeaderFooter = 0
Set oRange = Application.ActiveDocument.Range
oRange.Collapse (Word.WdCollapseDirection.wdCollapseEnd)
oRange.InsertBreak (Word.WdBreakType.wdSectionBreakNextPage)
'get the total number of sections now in the document
iNoOfSections = Application.ActiveDocument.Sections.Count
'unlink header and footer from the previous section
With Application.ActiveDocument.Sections(iNoOfSections).Headers(WdHeaderFooterIndex.wdHeaderFooterPrimary)
.LinkToPrevious = False
.Range.Delete
End With
With Application.ActiveDocument.Sections(iNoOfSections).Footers(WdHeaderFooterIndex.wdHeaderFooterPrimary)
.LinkToPrevious = False
.Range.Delete
End With
'adjust the bottom margin of this section
With Application.ActiveDocument.Sections(iNoOfSections)
.PageSetup.BottomMargin = Application.CentimetersToPoints(1.52)
End With
'get a range that represents the end of the document
Set objRange = Application.ActiveDocument.Range
objRange.Collapse (WdCollapseDirection.wdCollapseEnd)
' add a table with 1 column and 3 rows
Set oTable = Application.ActiveDocument.Tables.Add(Range:=oRange, NumRows:=3, NumColumns:=1)
sngTableWidthPoints = Application.ActiveDocument.PageSetup.PageWidth - _
(Application.ActiveDocument.PageSetup.LeftMargin + _
Application.ActiveDocument.PageSetup.RightMargin) + 8
With oTable
.PreferredWidthType = wdPreferredWidthPoints
.PreferredWidth = sngTableWidthPoints
' With .Rows
' .VerticalPosition = Word.WdTablePosition.wdTableBottom
' .RelativeVerticalPosition = Word.WdRelativeVerticalPosition.wdRelativeVerticalPositionMargin
' End With
With .Range.Font
.Name = "Expert Sans Regular"
.Size = 8
End With
End With
'get a range that represents the end of the document
Set oRange = Application.ActiveDocument.Range
oRange.Collapse (Word.WdCollapseDirection.wdCollapseEnd)
'selecting the line
oRange.Expand (WdUnits.wdParagraph)
oRange.Font.Name = "Expert Sans Regular"
oRange.Font.Size = 8
oRange.InsertParagraphAfter
oRange.Select
'get a range that represents the end of the document
Set oRange = Application.ActiveDocument.Range
oRange.Collapse (Word.WdCollapseDirection.wdCollapseEnd)
'add a table with 1 column and 1 row
Set oTable = Application.ActiveDocument.Tables.Add(Range:=objRange, NumRows:=1, NumColumns:=1)
With oTable
.PreferredWidthType = wdPreferredWidthPoints
.PreferredWidth = sngTableWidthPoints 'use the same width we calculated above
With .Range.Font
.Name = "Expert Sans Regular"
.Size = 8
End With
End With
End Sub
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext