mlreportgen.dom.FormalTable Class
Namespace: mlreportgen.dom
Formal table
Description
Defines a formal table, which is a table that has a body and optionally a table header, a
      table footer, or both. The table header, body, and footer are
        mlreportgen.dom.TableHeader, mlreportgen.dom.TableBody, and
        mlreportgen.dom.TableFooter objects, respectively.
The mlreportgen.dom.FormalTable class is a handle class.
Creation
Description
formalTableObj = FormalTable
formalTableObj = FormalTable(ncols)
formalTableObj = FormalTable(body)mlreportgen.dom.Text objects.
Note
Microsoft® Word automatically combines consecutive tables with matching style names into a single table. To render consecutive tables as separate tables in DOCX reports, do one of these options:
- Set the style names of the consecutive tables to different values. 
- Insert some content in between the tables. For example, insert an empty - mlreportgen.dom.Paragraphelement between the tables.
Input Arguments
Number of columns in a table, specified as a numeric value.
Data Types: double
Table body content, specified as:
- A two-dimensional numeric array 
- A two-dimensional categorical array 
- A two-dimensional cell array that can contain: - Character vectors 
- One- or two-dimensional cell array 
- double
- mlreportgen.dom.Textobject
- mlreportgen.dom.Paragraphobject
- mlreportgen.dom.Imageobject
- mlreportgen.dom.Tableobject
- mlreportgen.dom.FormalTableobject
- mlreportgen.dom.OrderedListobject
- mlreportgen.dom.UnorderedListobject
- mlreportgen.dom.ExternalLinkobject
- mlreportgen.dom.InternalLinkobject
- mlreportgen.dom.CharEntityobject
 
Style for the table, specified as a character vector or string scalar. The style in this property must be defined in the template used to create the document that contains this table.
The cell array may contain:
- Character vectors 
- One- or two-dimensional cell array 
- double
- mlreportgen.dom.Textobject
- mlreportgen.dom.Paragraphobject
- mlreportgen.dom.Imageobject
- mlreportgen.dom.Tableobject
- mlreportgen.dom.FormalTableobject
- mlreportgen.dom.OrderedListobject
- mlreportgen.dom.UnorderedListobject
- mlreportgen.dom.ExternalLinkobject
- mlreportgen.dom.InternalLinkobject
- mlreportgen.dom.CharEntityobject
The cell array may contain:
- Character vectors 
- One- or two-dimensional cell array 
- double
- mlreportgen.dom.Textobject
- mlreportgen.dom.Paragraphobject
- mlreportgen.dom.Imageobject
- mlreportgen.dom.Tableobject
- mlreportgen.dom.FormalTableobject
- mlreportgen.dom.OrderedListobject
- mlreportgen.dom.UnorderedListobject
- mlreportgen.dom.ExternalLinkobject
- mlreportgen.dom.InternalLinkobject
- mlreportgen.dom.CharEntityobject
Properties
Background color that contains a CSS color name or a hexadecimal RGB value, specified as a character vector or string scalar.
- To use the name of a color, specify a CSS color name. For a list of CSS color names, seehttps://www.w3.org/wiki/CSS/Properties/color/keywords. 
- To specify a hexadecimal RGB format, use - #as the first character and two-digit hexadecimal numbers for the red, green, and blue values. For example,- "#0000ff"specifies blue.
Note
Setting the BackgroundColor property adds a
                    mlreportgen.dom.BackgroundColor format object to the
                    Style property. Setting the
                    BackgroundColor property to an empty value removes the
                object.
Example: "blue"
Example: "#0000ff"
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
The table constructor creates a mlreportgen.dom.TableBody object and
            assigns it to this property when the formal table is constructed. You cannot
            subsequently set this property. However, you can append content to the table body and
            set its properties via this property.
Attributes:
| GetAccess | public | 
| SetAccess | private | 
| Transient | true | 
| NonCopyable | true | 
Type of border to draw, specified as one of these values:
| Border Style | Description | Supported in Microsoft Word | Supported in HTML and PDF | 
|---|---|---|---|
| "dashed" | Dashed line | yes | yes | 
| "dashdotstroked" | Line with alternating diagonal dashes and dot | yes | yes | 
| "dashsmallgap" | Dashed line with a small gap between dashes | yes | yes | 
| "dotted" | Dotted line | yes | yes | 
| "dotdash" | Line with alternating dots and dashes | yes | no | 
| "dotdotdash" | Line with alternating double dots and a dash | yes | no | 
| "double" | Double line | yes | yes | 
| "doublewave" | Double wavy line | yes | no | 
| "groove" | 3-D effect grooved line | no | yes | 
| "hidden" | No line When there is a conflicting border style, the
                             | no | yes | 
| "inset" | 3-D effect line | no | yes | 
| "none" | No line When there is a conflicting border style, the
                        conflicting border style takes precedence over  | yes | yes | 
| "outset" | 3-D effect line | yes | yes | 
| "ridge" | 3-D effect ridged line | no | yes | 
| "single" | Single line | yes | yes | 
| "solid" | Single line | no | yes | 
| "thick" | Thick line | yes | no | 
| "thickthinlargegap" | Dashed line with alternating thick and thin dashes with a large gap | yes | no | 
| "thickthinmediumgap" | Dashed line with alternating thick and thin dashes with a medium gap | yes | no | 
| "thickthinsmallgap" | Dashed line with alternating thick and thin dashes with a small gap | yes | no | 
| "thinthicklargegap" | Dashed line with alternating thin and thick dashes with a large gap | yes | no | 
| "thinthickmediumgap" | Dashed line with alternating thin and thick dashes with a medium gap | yes | no | 
| "thinthicksmallgap" | Dashed line with alternating thin and thick dashes with a small gap | yes | no | 
| "thinthickthinlargegap" | Dashed line with alternating thin and thick dashes with a large gap | yes | no | 
| "thinthickthinmediumgap" | Dashed line with alternating thin and thick dashes with a medium gap | yes | no | 
| "thinthickthinsmallgap" | Dashed line with alternating thin and thick dashes with a small gap | yes | no | 
| "threedemboss" | Embossed effect line | yes | no | 
| "threedengrave" | Engraved effect line | yes | no | 
| "triple" | Triple line | yes | no | 
| "wave" | Wavy line | yes | no | 
Note
For Microsoft Word reports, when you assign an mlreportgen.dom.Border object to
        the Style property of an
            mlreportgen.dom.TableHeaderEntry,
            mlreportgen.dom.TableEntry, or
            mlreportgen.dom.HorizontalRule object, the reporter does not support
            "inset" or "outset" styles for this
        property.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Whether to collapse borders of adjacent cells into a single border, specified as:
- "on"— Collapses borders of adjacent cells into a single border
- "off"— Keeps the borders of adjacent cells
Note
This property applies only to HTML documents.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Color of the border, specified as a character vector or string scalar that contains a CSS color name or hexadecimal RGB value.
- To use the name of a color, specify a CSS color name. For a list of CSS color names, seehttps://www.w3.org/wiki/CSS/Properties/color/keywords. 
- To specify a hexadecimal RGB format, use - #as the first character and two-digit hexadecimal numbers for the red, green, and blue values. For example,- "#0000ff"specifies blue.
Example: "blue"
Example: "#0000ff"
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Table border width, specified as character vector or string scalar that contains a
            number followed by an abbreviation for a unit of measurement. For example,
                "10px" specifies 10 pixels. Valid abbreviations are:
- "px"— Pixels
- "cm"— Centimeters
- "in"— Inches
- "mm"— Millimeters
- "pc"— Picas
- "pt"— Points
Example: "2pt"
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Style of the line that separates the columns of a table or table section, specified as one of these values:
| Border Style | Description | Supported in Microsoft Word | Supported in HTML and PDF | 
|---|---|---|---|
| "dashed" | Dashed line | yes | yes | 
| "dashdotstroked" | Line with alternating diagonal dashes and dot | yes | yes | 
| "dashsmallgap" | Dashed line with a small gap between dashes | yes | yes | 
| "dotted" | Dotted line | yes | yes | 
| "dotdash" | Line with alternating dots and dashes | yes | no | 
| "dotdotdash" | Line with alternating double dots and a dash | yes | no | 
| "double" | Double line | yes | yes | 
| "doublewave" | Double wavy line | yes | no | 
| "groove" | 3-D effect grooved line | no | yes | 
| "hidden" | No line When there is a conflicting border style, the
                             | no | yes | 
| "inset" | 3-D effect line | no | yes | 
| "none" | No line When there is a conflicting border style, the
                        conflicting border style takes precedence over  | yes | yes | 
| "outset" | 3-D effect line | yes | yes | 
| "ridge" | 3-D effect ridged line | no | yes | 
| "single" | Single line | yes | yes | 
| "solid" | Single line | no | yes | 
| "thick" | Thick line | yes | no | 
| "thickthinlargegap" | Dashed line with alternating thick and thin dashes with a large gap | yes | no | 
| "thickthinmediumgap" | Dashed line with alternating thick and thin dashes with a medium gap | yes | no | 
| "thickthinsmallgap" | Dashed line with alternating thick and thin dashes with a small gap | yes | no | 
| "thinthicklargegap" | Dashed line with alternating thin and thick dashes with a large gap | yes | no | 
| "thinthickmediumgap" | Dashed line with alternating thin and thick dashes with a medium gap | yes | no | 
| "thinthicksmallgap" | Dashed line with alternating thin and thick dashes with a small gap | yes | no | 
| "thinthickthinlargegap" | Dashed line with alternating thin and thick dashes with a large gap | yes | no | 
| "thinthickthinmediumgap" | Dashed line with alternating thin and thick dashes with a medium gap | yes | no | 
| "thinthickthinsmallgap" | Dashed line with alternating thin and thick dashes with a small gap | yes | no | 
| "threedemboss" | Embossed effect line | yes | no | 
| "threedengrave" | Engraved effect line | yes | no | 
| "triple" | Triple line | yes | no | 
| "wave" | Wavy line | yes | no | 
Note
For Microsoft Word reports, when you assign an mlreportgen.dom.Border object to
        the Style property of an
            mlreportgen.dom.TableHeaderEntry,
            mlreportgen.dom.TableEntry, or
            mlreportgen.dom.HorizontalRule object, the reporter does not support
            "inset" or "outset" styles for this
        property.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Color of the lines that separate the columns, specified as a character vector or string scalar that contains a CSS color name or a hexadecimal RGB value.
- To use the name of a color, specify a CSS color name. For a list of CSS color names, seehttps://www.w3.org/wiki/CSS/Properties/color/keywords. 
- To specify a hexadecimal RGB format, use - #as the first character and two-digit hexadecimal numbers for the red, green, and blue values. For example,- "#0000ff"specifies blue.
Example: "blue"
Example: "#0000ff"
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Width of the line separating table columns, specified as a character vector or string scalar that contains a number followed by an abbreviation of a unit of measurement. Valid abbreviations are:
- "px"— Pixels
- "cm"— Centimeters
- "in"— Inches
- "mm"— Millimeters
- "pc"— Picas
- "pt"— Points
Example: "10pt" specifies 10 points
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Properties of group of columns in the table, specified as an array of
                mlreportgen.dom.TableColSpecGroup objects. The first object
            applies to the first group of columns, the second object to the second group, and so on.
            Specify the number of columns that belong to each group by using the
                Span property of the TableColSpecGroup object.
            For example, if the first object has a span of 2, it applies to the first two columns.
            If the second group has a span of 3, it applies to the next three columns, and so
            on.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Text flow direction, specified as one of these values:
- "ltr"— Text flows from left to right
- "rtl"— Text flows from right to left
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
The table constructor creates a table footer object and assigns it to this property when the formal table is constructed. You cannot subsequently set this property. However, you can append content to the table body and set its properties via this property.
Attributes:
| GetAccess | public | 
| SetAccess | private | 
| Transient | true | 
| NonCopyable | true | 
Horizontal alignment of the table, specified as one of these values:
- "center"
- "left"
- "right"
Note
To prevent the overflow of large tables in PDF reports, set the
                                        Width property.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
The table constructor creates a table header object and assigns it to this property when the formal table is constructed. You cannot subsequently set this property. However, you can append content to the table body and set its properties via this property.
Attributes:
| GetAccess | public | 
| SetAccess | private | 
| Transient | true | 
| NonCopyable | true | 
Since R2024a
Option to make table columns sortable, specified as a numeric or logical
              1 (true) or 0
              (false).
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: logical
Whether the table contents stay on the same page, specified as a numeric or logical 1 (true) or 0 (false). The default value is empty and is equivalent to true.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: logical
Left margin of the table, specified as a character vector or string scalar that contains a number followed by an abbreviation of a unit of measurement. Valid abbreviations are:
- "px"— Pixels
- "cm"— Centimeters
- "in"— Inches
- "mm"— Millimeters
- "pc"— Picas
- "pt"— Points
Example: "10pt" specifies 10 points
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Style of the lines that separate the rows of a table or table section, specified as one of these values:
| Border Style | Description | Supported in Microsoft Word | Supported in HTML and PDF | 
|---|---|---|---|
| "dashed" | Dashed line | yes | yes | 
| "dashdotstroked" | Line with alternating diagonal dashes and dot | yes | yes | 
| "dashsmallgap" | Dashed line with a small gap between dashes | yes | yes | 
| "dotted" | Dotted line | yes | yes | 
| "dotdash" | Line with alternating dots and dashes | yes | no | 
| "dotdotdash" | Line with alternating double dots and a dash | yes | no | 
| "double" | Double line | yes | yes | 
| "doublewave" | Double wavy line | yes | no | 
| "groove" | 3-D effect grooved line | no | yes | 
| "hidden" | No line When there is a conflicting border style, the
                             | no | yes | 
| "inset" | 3-D effect line | no | yes | 
| "none" | No line When there is a conflicting border style, the
                        conflicting border style takes precedence over  | yes | yes | 
| "outset" | 3-D effect line | yes | yes | 
| "ridge" | 3-D effect ridged line | no | yes | 
| "single" | Single line | yes | yes | 
| "solid" | Single line | no | yes | 
| "thick" | Thick line | yes | no | 
| "thickthinlargegap" | Dashed line with alternating thick and thin dashes with a large gap | yes | no | 
| "thickthinmediumgap" | Dashed line with alternating thick and thin dashes with a medium gap | yes | no | 
| "thickthinsmallgap" | Dashed line with alternating thick and thin dashes with a small gap | yes | no | 
| "thinthicklargegap" | Dashed line with alternating thin and thick dashes with a large gap | yes | no | 
| "thinthickmediumgap" | Dashed line with alternating thin and thick dashes with a medium gap | yes | no | 
| "thinthicksmallgap" | Dashed line with alternating thin and thick dashes with a small gap | yes | no | 
| "thinthickthinlargegap" | Dashed line with alternating thin and thick dashes with a large gap | yes | no | 
| "thinthickthinmediumgap" | Dashed line with alternating thin and thick dashes with a medium gap | yes | no | 
| "thinthickthinsmallgap" | Dashed line with alternating thin and thick dashes with a small gap | yes | no | 
| "threedemboss" | Embossed effect line | yes | no | 
| "threedengrave" | Engraved effect line | yes | no | 
| "triple" | Triple line | yes | no | 
| "wave" | Wavy line | yes | no | 
Note
For Microsoft Word reports, when you assign an mlreportgen.dom.Border object to
        the Style property of an
            mlreportgen.dom.TableHeaderEntry,
            mlreportgen.dom.TableEntry, or
            mlreportgen.dom.HorizontalRule object, the reporter does not support
            "inset" or "outset" styles for this
        property.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Color of the lines that separate table rows, specified as a character vector or string scalar that contains a CSS color name or a hexadecimal RGB value.
- To use the name of a color, specify a CSS color name. For a list of CSS color names, seehttps://www.w3.org/wiki/CSS/Properties/color/keywords. 
- To specify a hexadecimal RGB format, use - #as the first character and two-digit hexadecimal numbers for the red, green, and blue values. For example,- "#0000ff"specifies blue.
Example: "blue"
Example: "#0000ff"
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Width of the row separator, specified as character vector or string scalar that contains a
            number followed by an abbreviation for a unit of measurement. For example,
                "10px" specifies 10 pixels. Valid abbreviations are:
- "px"— Pixels
- "cm"— Centimeters
- "in"— Inches
- "mm"— Millimeters
- "pc"— Picas
- "pt"— Points
Example: "5pt"
Attributes:
| NonCopyable | true | 
Data Types: char | string
Style to use for the table entries, specified as a cell array of format objects. The styles
                        specified by this property apply to the content of the table entries and not
                        to the entries themselves. For example, you can use this property to define
                        the font size of the table entries but not the type or color of the entry
                        borders. To specify the borders, set the Style property
                        of each entry.
Note
Be careful not to inadvertently overwrite a previous setting
                                        of this property. For example, setting the table
                                                TableEntriesHAlign property
                                        appends an HAlign format object to this
                                        property. To avoid overwriting this property, set this
                                        property before setting other table properties that append
                                        formats to this property.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: cell
Inner margin for the table entries, specified as character vector or string scalar that contains a number followed by an abbreviation for a unit of measurement. Valid abbreviations are:
- "px"— Pixels
- "cm"— Centimeters
- "in"— Inches
- "mm"— Millimeters
- "pc"— Picas
- "pt"— Points
Example: "10px" specifies 10 pixels
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Table width, specified as a character vector or string scalar that contains a number followed by an abbreviation for a unit of measurement. For example, "100%" specifies 100% of the page width in a PDF report, and 100% of the page width, minus the margins, for a Word report. Valid abbreviations are::
- px— Pixels
- cm— Centimeters
- in— Inches
- mm— Millimeters
- pc— Picas
- pt— Points
- %— Percent
Example: "5pt" specifies five points
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Style name in the document or document part style sheet, specified as a character vector or string scalar. You can set this property for any section of a formal table. Setting this property overrides the default style specified for formal tables in the document.
If you specify the StyleName of a section for a Word document,
            you must explicitly specify the width of each column in the section to ensure that all
            sections have the same width. Word has no built-in support for formal tables. To handle
            this, the DOM interface represents a formal table as three tables, one for each section,
            embedded in a 3x1 table.
This property does not support default Word document style names that have hyphens. To use a default Word document style name that has a hyphen, define the table style in a custom Word template and create the document or document part by using that template.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Format specification for this document element object, specified as an array of DOM
            format objects. The formats specified by this property override corresponding formats
            specified by the StyleName property of this element. Formats that
            do not apply to this document element object are ignored.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Custom attributes of the document element, specified as an array of mlreportgen.dom.CustomAttribute objects. The custom attributes must be
            supported by the output format of the document element to which this object is
            appended.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Parent of this object, specified as a document element object. A document element must have only one parent.
Attributes:
| GetAccess | public | 
| SetAccess | private | 
| NonCopyable | true | 
Children of this object, specified as an array of document element objects. This
            property contains the document element objects appended using the
                append method.
Attributes:
| GetAccess | public | 
| SetAccess | private | 
| NonCopyable | true | 
Tag, specified as a character vector or string scalar. The DOM API generates a
            session-unique tag as part of the creation of this object. The generated tag has the
            form CLASS:ID, where
                    CLASS is the object class and
                    ID is the value of the
                Id property of the object. Use this value to help identify
            where an issue occurs during document generation.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Object identifier, specified as a character vector or string scalar. The DOM API generates a session-unique identifier when it creates the document element object.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Methods
| Method | Purpose | 
|---|---|
| Use
                     | Append a row of table entries to table | 
| Append row to table footer | |
| Append row to table header | |
| Use
                     | Copy the table | 
Version History
Introduced in R2014bdatetime arrays in mlreportgen.dom.Table, mlreportgen.dom.FormalTable, and mlreportgen.dom.MATLABTable tables will now display as the point in time stored
        in the array.
| Before R2024b | Starting R2024b | 
|---|---|
| 
 | 
 | 
Make HTML table columns sortable by using the using the isSortable
        property in the mlreportgen.dom.FormalTable class.
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
![Three columns showing a datetime array, an integer, and a string. The datetime object displays as [1x1 datetime].](rn24b_datetime_old.png)
