Table
Contents
[
Hide
]Table class
Represents a table in a Word document.
To learn more, visit the Working with Tables documentation article.
public class Table : CompositeNode
Constructors
| Name | Description |
|---|---|
| Table(DocumentBase) | Initializes a new instance of the Table class. |
Properties
| Name | Description |
|---|---|
| AbsoluteHorizontalDistance { get; set; } | Gets or sets absolute horizontal floating table position specified by the table properties, in points. Default value is 0. |
| AbsoluteVerticalDistance { get; set; } | Gets or sets absolute vertical floating table position specified by the table properties, in points. Default value is 0. |
| Alignment { get; set; } | Specifies how an inline table is aligned in the document. |
| AllowAutoFit { get; set; } | Allows Microsoft Word and Aspose.Words to automatically resize cells in a table to fit their contents. |
| AllowCellSpacing { get; set; } | Gets or sets the “Allow spacing between cells” option. |
| AllowOverlap { get; } | Gets whether a floating table shall allow other floating objects in the document to overlap its extents when displayed. Default value is true. |
| Bidi { get; set; } | Gets or sets whether this is a right-to-left table. |
| BottomPadding { get; set; } | Gets or sets the amount of space (in points) to add below the contents of cells. |
| CellSpacing { get; set; } | Gets or sets the amount of space (in points) between the cells. |
| Count { get; } | Gets the number of immediate children of this node. |
| CustomNodeId { get; set; } | Specifies custom node identifier. |
| Description { get; set; } | Gets or sets description of this table. It provides an alternative text representation of the information contained in the table. |
| DistanceBottom { get; set; } | Gets or sets distance between table bottom and the surrounding text, in points. |
| DistanceLeft { get; set; } | Gets or sets distance between table left and the surrounding text, in points. |
| DistanceRight { get; set; } | Gets or sets distance between table right and the surrounding text, in points. |
| DistanceTop { get; set; } | Gets or sets distance between table top and the surrounding text, in points. |
| virtual Document { get; } | Gets the document to which this node belongs. |
| FirstChild { get; } | Gets the first child of the node. |
| FirstRow { get; } | Returns the first Row node in the table. |
| HasChildNodes { get; } | Returns true if this node has any child nodes. |
| HorizontalAnchor { get; set; } | Gets the base object from which the horizontal positioning of floating table should be calculated. Default value is Column. |
| override IsComposite { get; } | Returns true as this node can have child nodes. |
| LastChild { get; } | Gets the last child of the node. |
| LastRow { get; } | Returns the last Row node in the table. |
| LeftIndent { get; set; } | Gets or sets the value that represents the left indent of the table. |
| LeftPadding { get; set; } | Gets or sets the amount of space (in points) to add to the left of the contents of cells. |
| NextSibling { get; } | Gets the node immediately following this node. |
| override NodeType { get; } | Returns Table. |
| ParentNode { get; } | Gets the immediate parent of this node. |
| PreferredWidth { get; set; } | Gets or sets the table preferred width. |
| PreviousSibling { get; } | Gets the node immediately preceding this node. |
| Range { get; } | Returns a Range object that represents the portion of a document that is contained in this node. |
| RelativeHorizontalAlignment { get; set; } | Gets or sets floating table relative horizontal alignment. |
| RelativeVerticalAlignment { get; set; } | Gets or sets floating table relative vertical alignment. |
| RightPadding { get; set; } | Gets or sets the amount of space (in points) to add to the right of the contents of cells. |
| Rows { get; } | Provides typed access to the rows of the table. |
| Style { get; set; } | Gets or sets the table style applied to this table. |
| StyleIdentifier { get; set; } | Gets or sets the locale independent style identifier of the table style applied to this table. |
| StyleName { get; set; } | Gets or sets the name of the table style applied to this table. |
| StyleOptions { get; set; } | Gets or sets bit flags that specify how a table style is applied to this table. |
| TextWrapping { get; set; } | Gets or sets TextWrapping for table. |
| Title { get; set; } | Gets or sets title of this table. It provides an alternative text representation of the information contained in the table. |
| TopPadding { get; set; } | Gets or sets the amount of space (in points) to add above the contents of cells. |
| VerticalAnchor { get; set; } | Gets the base object from which the vertical positioning of floating table should be calculated. Default value is Margin. |
Methods
| Name | Description |
|---|---|
| override Accept(DocumentVisitor) | Accepts a visitor. |
| override AcceptEnd(DocumentVisitor) | Accepts a visitor for visiting the end of the table. |
| override AcceptStart(DocumentVisitor) | Accepts a visitor for visiting the start of the table. |
| AppendChild<T>(T) | Adds the specified node to the end of the list of child nodes for this node. |
| AutoFit(AutoFitBehavior) | Resizes the table and cells according to the specified auto fit behavior. |
| ClearBorders() | Removes all table and cell borders on this table. |
| ClearShading() | Removes all shading on the table. |
| Clone(bool) | Creates a duplicate of the node. |
| ConvertToHorizontallyMergedCells() | Converts cells horizontally merged by width to cells merged by HorizontalMerge. |
| CreateNavigator() | Creates navigator which can be used to traverse and read nodes. |
| EnsureMinimum() | If the table has no rows, creates and appends one Row. |
| GetAncestor(NodeType) | Gets the first ancestor of the specified NodeType. |
| GetAncestor(Type) | Gets the first ancestor of the specified object type. |
| GetChild(NodeType, int, bool) | Returns an Nth child node that matches the specified type. |
| GetChildNodes(NodeType, bool) | Returns a live collection of child nodes that match the specified type. |
| GetEnumerator() | Provides support for the for each style iteration over the child nodes of this node. |
| override GetText() | Gets the text of this node and of all its children. |
| IndexOf(Node) | Returns the index of the specified child node in the child node array. |
| InsertAfter<T>(T, Node) | Inserts the specified node immediately after the specified reference node. |
| InsertBefore<T>(T, Node) | Inserts the specified node immediately before the specified reference node. |
| NextPreOrder(Node) | Gets next node according to the pre-order tree traversal algorithm. |
| PrependChild<T>(T) | Adds the specified node to the beginning of the list of child nodes for this node. |
| PreviousPreOrder(Node) | Gets the previous node according to the pre-order tree traversal algorithm. |
| Remove() | Removes itself from the parent. |
| RemoveAllChildren() | Removes all the child nodes of the current node. |
| RemoveChild<T>(T) | Removes the specified child node. |
| RemoveSmartTags() | Removes all SmartTag descendant nodes of the current node. |
| SelectNodes(string) | Selects a list of nodes matching the XPath expression. |
| SelectSingleNode(string) | Selects the first Node that matches the XPath expression. |
| SetBorder(BorderType, LineStyle, double, Color, bool) | Sets the specified table border to the specified line style, width and color. |
| SetBorders(LineStyle, double, Color) | Sets all table borders to the specified line style, width and color. |
| SetShading(TextureIndex, Color, Color) | Sets shading to the specified values on whole table. |
| ToString(SaveFormat) | Exports the content of the node into a string in the specified format. |
| ToString(SaveOptions) | Exports the content of the node into a string using the specified save options. |
Remarks
Table is a block-level node and can be a child of classes derived from Story or InlineStory.
Table can contain one or more Row nodes.
A minimal valid table needs to have at least one Row.
Examples
Shows how to create a table.
Document doc = new Document();
Table table = new Table(doc);
doc.FirstSection.Body.AppendChild(table);
// Tables contain rows, which contain cells, which may have paragraphs
// with typical elements such as runs, shapes, and even other tables.
// Calling the "EnsureMinimum" method on a table will ensure that
// the table has at least one row, cell, and paragraph.
Row firstRow = new Row(doc);
table.AppendChild(firstRow);
Cell firstCell = new Cell(doc);
firstRow.AppendChild(firstCell);
Paragraph paragraph = new Paragraph(doc);
firstCell.AppendChild(paragraph);
// Add text to the first cell in the first row of the table.
Run run = new Run(doc, "Hello world!");
paragraph.AppendChild(run);
doc.Save(ArtifactsDir + "Table.CreateTable.docx");
Shows how to iterate through all tables in the document and print the contents of each cell.
Document doc = new Document(MyDir + "Tables.docx");
TableCollection tables = doc.FirstSection.Body.Tables;
Assert.That(tables.ToArray().Length, Is.EqualTo(2));
for (int i = 0; i < tables.Count; i++)
{
Console.WriteLine($"Start of Table {i}");
RowCollection rows = tables[i].Rows;
// We can use the "ToArray" method on a row collection to clone it into an array.
Assert.That(rows.ToArray(), Is.EqualTo(rows));
Assert.That(rows.ToArray(), Is.Not.SameAs(rows));
for (int j = 0; j < rows.Count; j++)
{
Console.WriteLine($"\tStart of Row {j}");
CellCollection cells = rows[j].Cells;
// We can use the "ToArray" method on a cell collection to clone it into an array.
Assert.That(cells.ToArray(), Is.EqualTo(cells));
Assert.That(cells.ToArray(), Is.Not.SameAs(cells));
for (int k = 0; k < cells.Count; k++)
{
string cellText = cells[k].ToString(SaveFormat.Text).Trim();
Console.WriteLine($"\t\tContents of Cell:{k} = \"{cellText}\"");
}
Console.WriteLine($"\tEnd of Row {j}");
}
Console.WriteLine($"End of Table {i}\n");
}
Shows how to build a formatted 2x2 table.
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
Table table = builder.StartTable();
builder.InsertCell();
builder.CellFormat.VerticalAlignment = CellVerticalAlignment.Center;
builder.Write("Row 1, cell 1.");
builder.InsertCell();
builder.Write("Row 1, cell 2.");
builder.EndRow();
// While building the table, the document builder will apply its current RowFormat/CellFormat property values
// to the current row/cell that its cursor is in and any new rows/cells as it creates them.
Assert.That(table.Rows[0].Cells[0].CellFormat.VerticalAlignment, Is.EqualTo(CellVerticalAlignment.Center));
Assert.That(table.Rows[0].Cells[1].CellFormat.VerticalAlignment, Is.EqualTo(CellVerticalAlignment.Center));
builder.InsertCell();
builder.RowFormat.Height = 100;
builder.RowFormat.HeightRule = HeightRule.Exactly;
builder.CellFormat.Orientation = TextOrientation.Upward;
builder.Write("Row 2, cell 1.");
builder.InsertCell();
builder.CellFormat.Orientation = TextOrientation.Downward;
builder.Write("Row 2, cell 2.");
builder.EndRow();
builder.EndTable();
// Previously added rows and cells are not retroactively affected by changes to the builder's formatting.
Assert.That(table.Rows[0].RowFormat.Height, Is.EqualTo(0));
Assert.That(table.Rows[0].RowFormat.HeightRule, Is.EqualTo(HeightRule.Auto));
Assert.That(table.Rows[1].RowFormat.Height, Is.EqualTo(100));
Assert.That(table.Rows[1].RowFormat.HeightRule, Is.EqualTo(HeightRule.Exactly));
Assert.That(table.Rows[1].Cells[0].CellFormat.Orientation, Is.EqualTo(TextOrientation.Upward));
Assert.That(table.Rows[1].Cells[1].CellFormat.Orientation, Is.EqualTo(TextOrientation.Downward));
doc.Save(ArtifactsDir + "DocumentBuilder.BuildTable.docx");
Shows how to build a nested table without using a document builder.
public void CreateNestedTable()
{
Document doc = new Document();
// Create the outer table with three rows and four columns, and then add it to the document.
Table outerTable = CreateTable(doc, 3, 4, "Outer Table");
doc.FirstSection.Body.AppendChild(outerTable);
// Create another table with two rows and two columns and then insert it into the first table's first cell.
Table innerTable = CreateTable(doc, 2, 2, "Inner Table");
outerTable.FirstRow.FirstCell.AppendChild(innerTable);
doc.Save(ArtifactsDir + "Table.CreateNestedTable.docx");
}
/// <summary>
/// Creates a new table in the document with the given dimensions and text in each cell.
/// </summary>
private static Table CreateTable(Document doc, int rowCount, int cellCount, string cellText)
{
Table table = new Table(doc);
for (int rowId = 1; rowId <= rowCount; rowId++)
{
Row row = new Row(doc);
table.AppendChild(row);
for (int cellId = 1; cellId <= cellCount; cellId++)
{
Cell cell = new Cell(doc);
cell.AppendChild(new Paragraph(doc));
cell.FirstParagraph.AppendChild(new Run(doc, cellText));
row.AppendChild(cell);
}
}
// You can use the "Title" and "Description" properties to add a title and description respectively to your table.
// The table must have at least one row before we can use these properties.
// These properties are meaningful for ISO / IEC 29500 compliant .docx documents (see the OoxmlCompliance class).
// If we save the document to pre-ISO/IEC 29500 formats, Microsoft Word ignores these properties.
table.Title = "Aspose table title";
table.Description = "Aspose table description";
return table;
}
See Also
- class CompositeNode
- namespace Aspose.Words.Tables
- assembly Aspose.Words