mlreportgen.report.Report Class
Namespace: mlreportgen.report
Report container
Description
An object of the mlreportgen.report.Report class is a container for a
            report consisting of reporters and MATLAB® and DOM objects. Use an mlreportgen.report.Report object to
            generate an HTML, PDF, or Word report based on templates in a template library.
Note
To create reports with Simulink® or Stateflow® content, use the slreportgen.report.Report (Simulink Report Generator) class.
The mlreportgen.report.Report class is a handle class.
Creation
Description
                    report = mlreportgen.report.Report
                    report = mlreportgen.report.Report(path)path.
                    report = mlreportgen.report.Report(path,type,template)template. 
report = mlreportgen.report.Report(Name=Value)
Properties
Path of the generated report file, specified as a character vector or string scalar.
            The path is the location in the file system of the report output document. The path can
            be a full path, for example, "C:/myreports/reportA.docx". The path
            can also be relative to the current MATLAB folder, for example,
                "reportA". If the file name does not have a file extension that
            corresponds to the Type property, the report generator adds the
            appropriate file extension when the report document is closed.
Note
Generating a PDF report on a cloud drive, such as MATLAB Drive™ or Microsoft® OneDrive™, can cause file contention between the report generation software and the cloud drive synchronization software resulting in a version of this error:
Error closing document package: Could not commit changes: removeAll failed: fl:filesystem:AccessDenied: C:\Users\jdoe\OneDrive\Documents\MATLAB\reports\temp_FO\stylesheets: Permission denied.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
Data Types: char | string
Output type, specified as one of these values:
- "docx"— Microsoft Word document.
- "html"— HTML report, packaged as a zipped file that contains the HTML file, images, style sheet, and JavaScript® files of the report. To generate an HTML report as a folder that contains unzipped files, set the- PackageTypeproperty to- "unzipped"or- "both".
- "html-file"— HTML report that consists of a single HTML file that contains the text, style sheets, JavaScript, and base64-encoded images of the report.
- "pdf"— PDF file.
- "pdfa"— PDF/A file. (since R2025a)
 If you specify a template using the TemplatePath
            property, the value for Type must match the template type.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
Data Types: char | string
Packaging to use for the generated files, specified as one of these values:
| Value | Supported Report Types | Description | 
|---|---|---|
| 
 | 
 | Generates the report as a ZIP file at the location
                                    specified by the  | 
| "unzipped" | 
 | Generates the report as separate files in a folder that has
                                    the file name of the  | 
| "both" | 
 | Generates zipped and unzipped outputs. | 
| "single-file" | 
 | Generates the report as a single file. | 
Tip
To generate an HTML report that you can open without unzipping when the
                    Type property is "html", set
                    PackageType to "unzipped" or
                    "both". In the folder that contains the generated files, open
                the root.html file.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Data Types: char | string
Location of the template to use to format this report, specified as a character vector or string scalar. You can use this property to specify a custom template for the report.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
Data Types: char | string
Locale or language, specified as a character vector or string scalar that consists of
            the ISO_639-1 two-letter language code of the locale for which this report is to be
            generated. The default value,
                [], specifies the language of the system locale, for example,
            English on an English system. The Report API uses the language code to translate chapter
            title prefixes to the language of the specified locale. Translations are provided for
            the following locales: 
- "af"
- "ca"
- "cs"
- "da"
- "de"
- "el"
- "en"
- "es"
- "et"
- "eu"
- "fi"
- "fr"
- "hu"
- "id"
- "it"
- "ja"
- "ko"
- "nl"
- "nn"
- "no"
- "pl"
- "pt"
- "ro"
- "ru"
- "sk"
- "sl"
- "sr"
- "sv"
- "tr"
- "uk"
- "xh"
- "zh"
. If you specify an unsupported locale, the English version is used. For more information, see List of ISO_639-1 codes on the Wikipedia website.
For an example, see Specify a Locale for Chapter Title Prefixes.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
Data Types: char | string
Debug mode, specified as a numeric or logical 1 (true) or 0 (false). If you set Debug to true or 1, the temporary files for the report are stored in a subfolder of the report folder and are not deleted when the report is closed.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
Data Types: logical
Page layout options for this report, specified as an mlreportgen.report.ReportLayout object. The default value of the
                Layout property is an
                mlreportgen.report.ReportLayout object with default values. Customize
            the page layout by modifying the property values. For an example, see Create a Landscape Report.
The layout options specified by the Layout property of objects of the mlreportgen.report.TitlePage, mlreportgen.report.TableOfContents, and mlreportgen.report.Chapter classes can override the page layout properties specified by the Layout property of an mlreportgen.report.Report object.
Note
The Layout property applies only to PDF and Word reports.
Attributes:
| GetAccess | public | 
| SetAccess | protected | 
DOM document object to use to generate the content of the report, specified as an
                mlreportgen.dom.Document object.
Attributes:
| GetAccess | public | 
| SetAccess | private | 
Report context, specified as a containers.Map object that contains the
            information to use to generate the report, such as the hierarchical level of the current
            report section.
Attributes:
| GetAccess | public | 
| SetAccess | private | 
Methods
| open | Opens the report | 
| append | Add content to report | 
| add | (Not recommended) Add content to report | 
| close | Close and generate report | 
| rptview | Open generated report file in viewer | 
| mlreportgen.report.Report.createTemplate | Create report template | 
| mlreportgen.report.Report.customizeReport | Create class derived from Report class | 
| mlreportgen.report.Report.getClassFolder | Report class definition file location | 
| getTempPath | Path of report temporary directory | 
| generateFileName | Generate temporary report file name | 
| getReportLayout | Current page layout of report | 
| fill | Fill report template holes | 
| getContext | Get report context value | 
| setContext | Set report context value | 
| removeContext | Remove report context value | 
| ispdf | Check if PDF report | 
| isdocx | Check if Word report | 
| ishtml | Check if multifile HTML report | 
| ishtmlfile | Check if single-file HTML report | 
Examples
Create a report using the Report API.
Import the DOM and Report API namespaces so that you do not have to use fully qualified class names.
import mlreportgen.report.* import mlreportgen.dom.*
Create the report container.
rpt = Report('My Report','pdf');
Add a title page, table of contents, and chapter to the report. The chapter contains two sections, each of which contains an image.
append(rpt,TitlePage(Title='My Report')); append(rpt,TableOfContents); ch = Chapter('Images'); append(ch,Section(Title='Boeing 747',... Content=Image(which('b747.jpg')))); append(ch,Section(Title='Peppers',... Content=Image(which('peppers.png')))); append(rpt,ch); close(rpt); rptview(rpt);
Create a report that has landscape orientation by using the Report API.
Import the Report API namespaces so that you do not have to use long, fully qualified class names.
import mlreportgen.report.*Create a report container. In the
                            mlreportgen.report.ReportLayout object assigned to the
                            Layout property, set the
                            Landscape property to
                        true.
rpt = Report("myreport","pdf"); rpt.Layout.Landscape = true;
Add content to the report. Generate and view the report.
append(rpt,TitlePage(Title="My Landscape Report")); append(rpt,TableOfContents); append(rpt,Chapter(Title="Tests")); append(rpt,Chapter(Title="Unit Tests")); close(rpt); rptview(rpt);
Set the chapter title prefixes of a report to Japanese by
                    setting the Locale property.
import mlreportgen.report.* rpt = Report("Japanese Report"); rpt.Locale = "ja"; house = char(23478); % Kanji character for house append(rpt, Chapter(house)); close(rpt); rptview(rpt);
Version History
Introduced in R2017bYou can output DOM and Report API reports in the PDF/A format.
Starting in R2020b, use the append method instead of the
                        add method to add content to objects of these Report API classes:
- mlreportgen.report.Report
- mlreportgen.report.Chapter
- mlreportgen.report.Section
- slreportgen.report.Report
To add content to a DOM API object, such as an
                        mlreportgen.dom.Paragraph object, continue to use the
                        append method of the DOM object. The advantage of using
                        append to add content to Report API objects is that you use
                the same method name as you use to add content to DOM API objects.
There are no plans to remove the add methods of the
                        Report, Chapter, or Section
                classes. Report API programs that use the add methods will continue
                to run. 
To update existing code, replace the method name add with
                        append as shown by the examples in the table.
| Not Recommended | Recommended | 
|---|---|
| import mlreportgen.report.* import mlreportgen.dom.* rpt = Report("My Report","pdf"); ch = Chapter("My Chapter"); sect = Section("My Section"); para = Paragraph("My Content "); append(para,"more Content"); add(sect,para); add(ch,sect); add(rpt,ch); close(rpt); rptview(rpt); | import mlreportgen.report.* import mlreportgen.dom.* rpt = Report("My Report","pdf"); ch = Chapter("My Chapter"); sect = Section("My Section"); para = Paragraph("My Content "); append(para,"more Content"); append(sect,para); append(ch,sect); append(rpt,ch); close(rpt); rptview(rpt); | 
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.
Sélectionner un site web
Choisissez un site web pour accéder au contenu traduit dans votre langue (lorsqu'il est disponible) et voir les événements et les offres locales. D’après votre position, nous vous recommandons de sélectionner la région suivante : .
Vous pouvez également sélectionner un site web dans la liste suivante :
Comment optimiser les performances du site
Pour optimiser les performances du site, sélectionnez la région Chine (en chinois ou en anglais). Les sites de MathWorks pour les autres pays ne sont pas optimisés pour les visites provenant de votre région.
Amériques
- 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)