Export Report
Exports a report created in IBM RPA Studio, according to the defined format.
Command availability: IBM RPA SaaS and IBM RPA on premises
Script syntax
IBM RPA's proprietary script language has a syntax similar to other programming languages. The script syntax defines the command's syntax in the script file. You can work with this syntax in RPA Studio's Script mode.
exportReport --format(ReportFormats) [--title(String)] [--author(String)] --watermark(ReportWatermark) --encoding(Nullable<EncodingType>) [--createrandomfile(Boolean)] --filepath(String) [--password(String)] --asset(String) [--automap(Boolean)] --mappings(String) --text(String) --textcolor(String) [--textfont(String)] --textsize(Numeric) --image(String) --transparency(Numeric) [--pagerange(String)] (String)=filepath (Numeric)=pagecount
Input parameters
The following table displays the list of input parameters available in this command. In the table, you can see the parameter name when working in RPA Studio's Script mode and its Designer mode equivalent label.
Designer mode label | Script mode name | Required | Accepted variable types | Description |
---|---|---|---|---|
Format | format |
Required |
ReportFormats |
Format in which the report will be generated. |
Title | title |
Optional |
Text |
Title of the exported report. |
Author | author |
Optional |
Text |
Name of the report's author. |
Watermark | watermark |
Only when Format is Html, Rtf, or Docx |
ReportWatermark |
Watermark present in the report. The command accepts the following types: Image, Text, or None. See the watermark parameter options for details. |
Encoding | encoding |
Only when Format is Text or Csv |
EncodingType |
Type of character encoding used. |
Create random file | createrandomfile |
Optional |
Boolean |
Enable it to create a report file at random. |
File path | filepath |
Only when Create random file is False |
Text |
Report file path. |
Password | password |
Optional |
Text |
Password to unlock the file for viewing. |
Asset | asset |
Required |
Text |
Asset that contains the report template to be used. |
Automap | automap |
Optional |
Boolean |
Enable it to map variables that have the same type as the report parameters. |
Mappings | mappings |
Only when Automap is False |
Text, Database connection |
Maps which variables will fill the report parameters. The Parameter field receives the report name and the Value field receives the variable with the value. Check the Example to have a context on how to use it. |
Text | text |
Only when Watermark is Text |
Text |
Text used as a watermark. |
Text color | textcolor |
Only when Watermark is Text |
Text |
Color of the text in hexadecimal format. |
Text font | textfont |
Optional |
Text |
Font type applied to the text. |
Text size | textsize |
Only when Watermark is Text |
Number |
Font size. |
Image | image |
Only when Watermark is Image |
Text, Image |
Image used as a watermark. |
Transparency | transparency |
Only when Watermark is Text or Image |
Number |
Degree of transparency of the watermark. |
Page range | pagerange |
Optional when Watermark is Text or Image |
Text |
Range of pages where the watermark appears. |
watermark
parameter options
The following table displays the options available for the watermark
input parameter. The table shows the options available when working in Script mode and the equivalent label in the Designer mode.
Designer mode label | Script mode name | Description |
---|---|---|
Image | image |
The watermark is an Image. |
Text | text |
The watermark is a Text. |
Output parameters
Designer mode label | Script mode name | Accepted variable types | Description |
---|---|---|---|
File path | filepath |
Text |
Return the path of the generated report. |
Page count | pagecount |
Number |
Return the amount of printed pages. |
Example
The following example creates a simple report using an SQL Server database as a data source. The report contains data about the clients of a coffee shop and is exported as a PDF file.
import --name report --type "File" --content ﻿<?xml version="1.0" encoding="utf-8"?>
<XtraReportsLayoutSerializer SerializerVersion="23.1.3.0" Ref="1" ControlType="DevExpress.XtraReports.UI.XtraReport, DevExpress.XtraReports.v23.1, Version=23.1.3.0, Culture=neutral, PublicKeyToken=b88d1754d700e49a" Name="Report1" PageWidth="850" PageHeight="1100" Version="23.1" DataSource="#Ref-0" Font="Arial, 9.75pt">
  <Bands>
    <Item1 Ref="2" ControlType="TopMarginBand" Name="TopMargin" />
    <Item2 Ref="3" ControlType="BottomMarginBand" Name="BottomMargin">
      <Controls>
        <Item1 Ref="4" ControlType="XRPageInfo" Name="pageInfo1" PageInfo="DateTime" SizeF="325,23" LocationFloat="0,0" StyleName="PageInfo" />
        <Item2 Ref="5" ControlType="XRPageInfo" Name="pageInfo2" TextFormatString="Page {0} of {1}" TextAlignment="TopRight" SizeF="325,23" LocationFloat="325,0" StyleName="PageInfo" />
      </Controls>
    </Item2>
    <Item3 Ref="6" ControlType="ReportHeaderBand" Name="ReportHeader" HeightF="60">
      <Controls>
        <Item1 Ref="7" ControlType="XRLabel" Name="label1" Text="Client Reports" SizeF="650,24.194334" LocationFloat="0,0" StyleName="Title" />
      </Controls>
    </Item3>
    <Item4 Ref="8" ControlType="DetailBand" Name="Detail" HeightF="0" />
    <Item5 Ref="9" ControlType="DetailReportBand" Name="DetailReport" Level="0" DataMember="clients" DataSource="#Ref-0">
      <Bands>
        <Item1 Ref="10" ControlType="GroupHeaderBand" Name="GroupHeader1" GroupUnion="WithFirstDetail" Level="1" HeightF="27">
          <GroupFields>
            <Item1 Ref="11" FieldName="email" />
          </GroupFields>
          <Controls>
            <Item1 Ref="12" ControlType="XRTable" Name="table1" SizeF="650,25" LocationFloat="0,2">
              <Rows>
                <Item1 Ref="13" ControlType="XRTableRow" Name="tableRow1" Weight="1">
                  <Cells>
                    <Item1 Ref="14" ControlType="XRTableCell" Name="tableCell1" Weight="0.067146717951847956" Text="EMAIL" StyleName="GroupCaption2" />
                    <Item2 Ref="15" ControlType="XRTableCell" Name="tableCell2" Weight="0.93285334660456731" StyleName="GroupData2">
                      <ExpressionBindings>
                        <Item1 Ref="16" EventName="BeforePrint" PropertyName="Text" Expression="[email]" />
                      </ExpressionBindings>
                    </Item2>
                  </Cells>
                </Item1>
              </Rows>
            </Item1>
          </Controls>
        </Item1>
        <Item2 Ref="17" ControlType="GroupHeaderBand" Name="GroupHeader2" GroupUnion="WithFirstDetail" Level="2" HeightF="27">
          <GroupFields>
            <Item1 Ref="18" FieldName="last_name" />
          </GroupFields>
          <Controls>
            <Item1 Ref="19" ControlType="XRTable" Name="table2" SizeF="650,25" LocationFloat="0,2">
              <Rows>
                <Item1 Ref="20" ControlType="XRTableRow" Name="tableRow2" Weight="1">
                  <Cells>
                    <Item1 Ref="21" ControlType="XRTableCell" Name="tableCell3" Weight="1226127.375" Text="LAST NAME" StyleName="GroupCaption2" />
                    <Item2 Ref="22" ControlType="XRTableCell" Name="tableCell4" Weight="9423472" StyleName="GroupData2">
                      <ExpressionBindings>
                        <Item1 Ref="23" EventName="BeforePrint" PropertyName="Text" Expression="[last_name]" />
                      </ExpressionBindings>
                    </Item2>
                  </Cells>
                </Item1>
              </Rows>
            </Item1>
          </Controls>
        </Item2>
        <Item3 Ref="24" ControlType="GroupHeaderBand" Name="GroupHeader3" GroupUnion="WithFirstDetail" Level="3" HeightF="27">
          <GroupFields>
            <Item1 Ref="25" FieldName="first_name" />
          </GroupFields>
          <Controls>
            <Item1 Ref="26" ControlType="XRTable" Name="table3" SizeF="650,25" LocationFloat="0,2">
              <Rows>
                <Item1 Ref="27" ControlType="XRTableRow" Name="tableRow3" Weight="1">
                  <Cells>
                    <Item1 Ref="28" ControlType="XRTableCell" Name="tableCell5" Weight="0.12003132746769832" Text="FIRST NAME" StyleName="GroupCaption2" />
                    <Item2 Ref="29" ControlType="XRTableCell" Name="tableCell6" Weight="0.87996873121995189" StyleName="GroupData2">
                      <ExpressionBindings>
                        <Item1 Ref="30" EventName="BeforePrint" PropertyName="Text" Expression="[first_name]" />
                      </ExpressionBindings>
                    </Item2>
                  </Cells>
                </Item1>
              </Rows>
            </Item1>
          </Controls>
        </Item3>
        <Item4 Ref="31" ControlType="DetailBand" Name="Detail1" HeightF="0" />
        <Item5 Ref="32" ControlType="GroupFooterBand" Name="GroupFooter1" GroupUnion="WithLastDetail" HeightF="6">
          <Controls>
            <Item1 Ref="33" ControlType="XRLabel" Name="label2" SizeF="650,2.08" LocationFloat="0,0" StyleName="GroupFooterBackground3" Borders="None">
              <StylePriority Ref="34" UseBorders="false" />
            </Item1>
          </Controls>
        </Item5>
      </Bands>
    </Item5>
    <Item6 Ref="35" ControlType="DetailReportBand" Name="DetailReport1" Level="1" DataMember="order_items" DataSource="#Ref-0">
      <Bands>
        <Item1 Ref="36" ControlType="DetailBand" Name="Detail2" HeightF="0" />
      </Bands>
    </Item6>
    <Item7 Ref="37" ControlType="DetailReportBand" Name="DetailReport2" Level="2" DataMember="orders" DataSource="#Ref-0">
      <Bands>
        <Item1 Ref="38" ControlType="DetailBand" Name="Detail3" HeightF="0" />
      </Bands>
    </Item7>
    <Item8 Ref="39" ControlType="DetailReportBand" Name="DetailReport3" Level="3" DataMember="products" DataSource="#Ref-0">
      <Bands>
        <Item1 Ref="40" ControlType="DetailBand" Name="Detail4" HeightF="0" />
      </Bands>
    </Item8>
  </Bands>
  <StyleSheet>
    <Item1 Ref="41" Name="Title" BorderStyle="Inset" Padding="6,6,0,0,100" Font="Arial, 14.25pt" ForeColor="255,75,75,75" BackColor="Transparent" BorderColor="Black" Sides="None" StringFormat="Near;Near;0;None;Character;GenericDefault" BorderWidthSerializable="1" />
    <Item2 Ref="42" Name="GroupCaption2" BorderStyle="Inset" Padding="6,2,0,0,100" Font="Arial, 8.25pt, style=Bold" ForeColor="255,228,228,228" BackColor="255,111,111,111" BorderColor="White" Sides="Bottom" StringFormat="Near;Center;0;None;Character;GenericDefault" TextAlignment="MiddleLeft" BorderWidthSerializable="2" />
    <Item3 Ref="43" Name="GroupData2" BorderStyle="Inset" Padding="6,2,0,0,100" Font="Arial, 8.25pt, style=Bold" ForeColor="White" BackColor="255,111,111,111" BorderColor="White" Sides="Bottom" StringFormat="Near;Center;0;None;Character;GenericDefault" TextAlignment="MiddleLeft" BorderWidthSerializable="2" />
    <Item4 Ref="44" Name="GroupFooterBackground3" BorderStyle="Inset" Padding="6,2,0,0,100" Font="Arial, 8.25pt, style=Bold" ForeColor="255,228,228,228" BackColor="255,131,131,131" BorderColor="White" Sides="Bottom" StringFormat="Near;Center;0;None;Character;GenericDefault" TextAlignment="MiddleLeft" BorderWidthSerializable="2" />
    <Item5 Ref="45" Name="PageInfo" BorderStyle="Inset" Padding="6,6,0,0,100" Font="Arial, 8.25pt, style=Bold" ForeColor="255,75,75,75" StringFormat="Near;Near;0;None;Character;GenericDefault" />
  </StyleSheet>
  <ComponentStorage>
    <Item1 Ref="0" ObjectType="DevExpress.DataAccess.Sql.SqlDataSource,DevExpress.DataAccess.v23.1" Name="sqlDataSource" Base64="PFNxbERhdGFTb3VyY2UgTmFtZT0ic3FsRGF0YVNvdXJjZSI+PENvbm5lY3Rpb24gTmFtZT0iY2xpZW50cyIgUHJvdmlkZXJLZXk9IlNRTGl0ZSI+PFBhcmFtZXRlcnM+PFBhcmFtZXRlciBOYW1lPSJkYXRhYmFzZSIgVmFsdWU9IkM6XFVzZXJzXFcwMDAzODYzMVxEZXNrdG9wXGNsaWVudHMuZGIiIC8+PFBhcmFtZXRlciBOYW1lPSJyZWFkIG9ubHkiIFZhbHVlPSIxIiAvPjxQYXJhbWV0ZXIgTmFtZT0iZ2VuZXJhdGVDb25uZWN0aW9uSGVscGVyIiBWYWx1ZT0iZmFsc2UiIC8+PC9QYXJhbWV0ZXJzPjwvQ29ubmVjdGlvbj48UXVlcnkgVHlwZT0iU2VsZWN0UXVlcnkiIE5hbWU9ImNsaWVudHMiPjxUYWJsZXM+PFRhYmxlIE5hbWU9ImNsaWVudHMiIC8+PC9UYWJsZXM+PENvbHVtbnM+PENvbHVtbiBUYWJsZT0iY2xpZW50cyIgTmFtZT0iY2xpZW50X2lkIiAvPjxDb2x1bW4gVGFibGU9ImNsaWVudHMiIE5hbWU9ImZpcnN0X25hbWUiIC8+PENvbHVtbiBUYWJsZT0iY2xpZW50cyIgTmFtZT0ibGFzdF9uYW1lIiAvPjxDb2x1bW4gVGFibGU9ImNsaWVudHMiIE5hbWU9ImVtYWlsIiAvPjwvQ29sdW1ucz48L1F1ZXJ5PjxRdWVyeSBUeXBlPSJTZWxlY3RRdWVyeSIgTmFtZT0ib3JkZXJfaXRlbXMiPjxUYWJsZXM+PFRhYmxlIE5hbWU9Im9yZGVyX2l0ZW1zIiAvPjwvVGFibGVzPjxDb2x1bW5zPjxDb2x1bW4gVGFibGU9Im9yZGVyX2l0ZW1zIiBOYW1lPSJvcmRlcl9pdGVtX2lkIiAvPjxDb2x1bW4gVGFibGU9Im9yZGVyX2l0ZW1zIiBOYW1lPSJvcmRlcl9pZCIgLz48Q29sdW1uIFRhYmxlPSJvcmRlcl9pdGVtcyIgTmFtZT0icHJvZHVjdF9pZCIgLz48Q29sdW1uIFRhYmxlPSJvcmRlcl9pdGVtcyIgTmFtZT0icXVhbnRpdHkiIC8+PC9Db2x1bW5zPjwvUXVlcnk+PFF1ZXJ5IFR5cGU9IlNlbGVjdFF1ZXJ5IiBOYW1lPSJvcmRlcnMiPjxUYWJsZXM+PFRhYmxlIE5hbWU9Im9yZGVycyIgLz48L1RhYmxlcz48Q29sdW1ucz48Q29sdW1uIFRhYmxlPSJvcmRlcnMiIE5hbWU9Im9yZGVyX2lkIiAvPjxDb2x1bW4gVGFibGU9Im9yZGVycyIgTmFtZT0iY2xpZW50X2lkIiAvPjwvQ29sdW1ucz48L1F1ZXJ5PjxRdWVyeSBUeXBlPSJTZWxlY3RRdWVyeSIgTmFtZT0icHJvZHVjdHMiPjxUYWJsZXM+PFRhYmxlIE5hbWU9InByb2R1Y3RzIiAvPjwvVGFibGVzPjxDb2x1bW5zPjxDb2x1bW4gVGFibGU9InByb2R1Y3RzIiBOYW1lPSJwcm9kdWN0X2lkIiAvPjxDb2x1bW4gVGFibGU9InByb2R1Y3RzIiBOYW1lPSJuYW1lIiAvPjxDb2x1bW4gVGFibGU9InByb2R1Y3RzIiBOYW1lPSJwcmljZSIgLz48L0NvbHVtbnM+PC9RdWVyeT48UmVzdWx0U2NoZW1hPjxEYXRhU2V0IE5hbWU9InNxbERhdGFTb3VyY2UiPjxWaWV3IE5hbWU9ImNsaWVudHMiPjxGaWVsZCBOYW1lPSJjbGllbnRfaWQiIFR5cGU9IkludDY0IiAvPjxGaWVsZCBOYW1lPSJmaXJzdF9uYW1lIiBUeXBlPSJTdHJpbmciIC8+PEZpZWxkIE5hbWU9Imxhc3RfbmFtZSIgVHlwZT0iU3RyaW5nIiAvPjxGaWVsZCBOYW1lPSJlbWFpbCIgVHlwZT0iU3RyaW5nIiAvPjwvVmlldz48VmlldyBOYW1lPSJvcmRlcl9pdGVtcyI+PEZpZWxkIE5hbWU9Im9yZGVyX2l0ZW1faWQiIFR5cGU9IkludDY0IiAvPjxGaWVsZCBOYW1lPSJvcmRlcl9pZCIgVHlwZT0iSW50NjQiIC8+PEZpZWxkIE5hbWU9InByb2R1Y3RfaWQiIFR5cGU9IkludDY0IiAvPjxGaWVsZCBOYW1lPSJxdWFudGl0eSIgVHlwZT0iSW50NjQiIC8+PC9WaWV3PjxWaWV3IE5hbWU9Im9yZGVycyI+PEZpZWxkIE5hbWU9Im9yZGVyX2lkIiBUeXBlPSJJbnQ2NCIgLz48RmllbGQgTmFtZT0iY2xpZW50X2lkIiBUeXBlPSJJbnQ2NCIgLz48L1ZpZXc+PFZpZXcgTmFtZT0icHJvZHVjdHMiPjxGaWVsZCBOYW1lPSJwcm9kdWN0X2lkIiBUeXBlPSJJbnQ2NCIgLz48RmllbGQgTmFtZT0ibmFtZSIgVHlwZT0iU3RyaW5nIiAvPjxGaWVsZCBOYW1lPSJwcmljZSIgVHlwZT0iRG91YmxlIiAvPjwvVmlldz48L0RhdGFTZXQ+PC9SZXN1bHRTY2hlbWE+PENvbm5lY3Rpb25PcHRpb25zIENsb3NlQ29ubmVjdGlvbj0idHJ1ZSIgLz48L1NxbERhdGFTb3VyY2U+" />
  </ComponentStorage>
</XtraReportsLayoutSerializer> --extension ".repx"
defVar --name databaseConnection --type DbConnection --output
defVar --name hasResult --type Boolean
defVar --name path --type String
defVar --name result --type String
defVar --name connectionString --type String
getSpecialFolder --folder "Desktop" path=value
setVar --name "${connectionString}" --value "Server=(localdb)\\mssqllocaldb;Database=automation;User Id=<user>;Password=<pass>;"
sqlServerConnect --connectionstring "${connectionString}"
sqlExecute --connection ${databaseConnection} --statement "CREATE TABLE IF NOT EXISTS clients (client_id INTEGER PRIMARY KEY AUTOINCREMENT,first_name TEXT NOT NULL,last_name TEXT NOT NULL,email TEXT NOT NULL);"
sqlExecute --connection ${databaseConnection} --statement "CREATE TABLE IF NOT EXISTS products (product_id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT NOT NULL,price REAL NOT NULL);"
sqlExecute --connection ${databaseConnection} --statement "CREATE TABLE IF NOT EXISTS orders (order_id INTEGER PRIMARY KEY AUTOINCREMENT,client_id INTEGER,FOREIGN KEY(client_id) REFERENCES clients(client_id));"
sqlExecute --connection ${databaseConnection} --statement "CREATE TABLE IF NOT EXISTS order_items (order_item_id INTEGER PRIMARY KEY AUTOINCREMENT,order_id INTEGER,product_id INTEGER NOT NULL,quantity INTEGER NOT NULL,FOREIGN KEY(order_id) REFERENCES orders(order_id),FOREIGN KEY(product_id) REFERENCES products(product_id));"
sqlExecuteScalar --connection ${databaseConnection} --statement "SELECT COUNT(*) FROM orders;" result=value hasResult=hasresult
if --left "${hasResult}" --operator "Is_True" --negate
sqlExecute --connection ${databaseConnection} --statement "INSERT INTO clients (first_name, last_name, email)\r\nVALUES\r\n(\'John\', \'Doe\', \'john.doe@example.com\'),\r\n(\'Jane\', \'Doe\', \'jane.doe@example.com\'),\r\n(\'Peter\', \'Parker\', \'peter.parker@example.com\'),\r\n(\'Bruce\', \'Wayne\', \'bruce.wayne@example.com\'),\r\n(\'Clark\', \'Kent\', \'clark.kent@example.com\');"
sqlExecute --connection ${databaseConnection} --statement "INSERT INTO products (name, price)\r\nVALUES\r\n(\'Espresso\', 3.99),\r\n(\'Latte\', 4.99),\r\n(\'Capuccino\', 5.99),\r\n(\'Macchiato\', 4.50),\r\n(\'Americano\', 3.50),\r\n(\'Iced coffee\', 4.50),\r\n(\'Cold brew coffee\', 5.00),\r\n(\'Frappuccino\', 6.00),\r\n(\'Mocha\', 5.50),\r\n(\'White chocolate mocha\', 6.00);"
sqlExecute --connection ${databaseConnection} --statement "INSERT INTO orders (client_id)\r\nVALUES\r\n(1),\r\n(2),\r\n(3),\r\n(4),\r\n(5);"
sqlExecute --connection ${databaseConnection} --statement "INSERT INTO order_items (order_id, product_id, quantity)\r\nVALUES\r\n(1, 1, 2),\r\n(1, 2, 1),\r\n(2, 3, 3),\r\n(2, 4, 1),\r\n(3, 5, 2),\r\n(3, 6, 1),\r\n(4, 7, 3),\r\n(4, 8, 1),\r\n(5, 9, 2),\r\n(5, 10, 1);"
endIf
exportReport --format "Pdf" --watermark "None" --filepath "${path}\\myReport.pdf" --asset "${asset.report}" --automap
Server=(localdb)\\mssqllocaldb;Database=automation;User Id=<user>;Password=<pass>
with a valid
connection string.If you use a database as a data source and you want to map variables individually, check the name of the database variable under the Properties tab in the Report view in IBM RPA Studio. By default, the database variable is named
sqlDataSource
. The previous script with manually mapped parameters looks as follows:
import --name report --type "File" --content ﻿<?xml version="1.0" encoding="utf-8"?>
<XtraReportsLayoutSerializer SerializerVersion="23.1.3.0" Ref="1" ControlType="DevExpress.XtraReports.UI.XtraReport, DevExpress.XtraReports.v23.1, Version=23.1.3.0, Culture=neutral, PublicKeyToken=b88d1754d700e49a" Name="Report1" PageWidth="850" PageHeight="1100" Version="23.1" DataSource="#Ref-0" Font="Arial, 9.75pt">
  <Bands>
    <Item1 Ref="2" ControlType="TopMarginBand" Name="TopMargin" />
    <Item2 Ref="3" ControlType="BottomMarginBand" Name="BottomMargin">
      <Controls>
        <Item1 Ref="4" ControlType="XRPageInfo" Name="pageInfo1" PageInfo="DateTime" SizeF="325,23" LocationFloat="0,0" StyleName="PageInfo" />
        <Item2 Ref="5" ControlType="XRPageInfo" Name="pageInfo2" TextFormatString="Page {0} of {1}" TextAlignment="TopRight" SizeF="325,23" LocationFloat="325,0" StyleName="PageInfo" />
      </Controls>
    </Item2>
    <Item3 Ref="6" ControlType="ReportHeaderBand" Name="ReportHeader" HeightF="60">
      <Controls>
        <Item1 Ref="7" ControlType="XRLabel" Name="label1" Text="Client Reports" SizeF="650,24.194334" LocationFloat="0,0" StyleName="Title" />
      </Controls>
    </Item3>
    <Item4 Ref="8" ControlType="DetailBand" Name="Detail" HeightF="0" />
    <Item5 Ref="9" ControlType="DetailReportBand" Name="DetailReport" Level="0" DataMember="clients" DataSource="#Ref-0">
      <Bands>
        <Item1 Ref="10" ControlType="GroupHeaderBand" Name="GroupHeader1" GroupUnion="WithFirstDetail" Level="1" HeightF="27">
          <GroupFields>
            <Item1 Ref="11" FieldName="email" />
          </GroupFields>
          <Controls>
            <Item1 Ref="12" ControlType="XRTable" Name="table1" SizeF="650,25" LocationFloat="0,2">
              <Rows>
                <Item1 Ref="13" ControlType="XRTableRow" Name="tableRow1" Weight="1">
                  <Cells>
                    <Item1 Ref="14" ControlType="XRTableCell" Name="tableCell1" Weight="0.067146717951847956" Text="EMAIL" StyleName="GroupCaption2" />
                    <Item2 Ref="15" ControlType="XRTableCell" Name="tableCell2" Weight="0.93285334660456731" StyleName="GroupData2">
                      <ExpressionBindings>
                        <Item1 Ref="16" EventName="BeforePrint" PropertyName="Text" Expression="[email]" />
                      </ExpressionBindings>
                    </Item2>
                  </Cells>
                </Item1>
              </Rows>
            </Item1>
          </Controls>
        </Item1>
        <Item2 Ref="17" ControlType="GroupHeaderBand" Name="GroupHeader2" GroupUnion="WithFirstDetail" Level="2" HeightF="27">
          <GroupFields>
            <Item1 Ref="18" FieldName="last_name" />
          </GroupFields>
          <Controls>
            <Item1 Ref="19" ControlType="XRTable" Name="table2" SizeF="650,25" LocationFloat="0,2">
              <Rows>
                <Item1 Ref="20" ControlType="XRTableRow" Name="tableRow2" Weight="1">
                  <Cells>
                    <Item1 Ref="21" ControlType="XRTableCell" Name="tableCell3" Weight="1226127.375" Text="LAST NAME" StyleName="GroupCaption2" />
                    <Item2 Ref="22" ControlType="XRTableCell" Name="tableCell4" Weight="9423472" StyleName="GroupData2">
                      <ExpressionBindings>
                        <Item1 Ref="23" EventName="BeforePrint" PropertyName="Text" Expression="[last_name]" />
                      </ExpressionBindings>
                    </Item2>
                  </Cells>
                </Item1>
              </Rows>
            </Item1>
          </Controls>
        </Item2>
        <Item3 Ref="24" ControlType="GroupHeaderBand" Name="GroupHeader3" GroupUnion="WithFirstDetail" Level="3" HeightF="27">
          <GroupFields>
            <Item1 Ref="25" FieldName="first_name" />
          </GroupFields>
          <Controls>
            <Item1 Ref="26" ControlType="XRTable" Name="table3" SizeF="650,25" LocationFloat="0,2">
              <Rows>
                <Item1 Ref="27" ControlType="XRTableRow" Name="tableRow3" Weight="1">
                  <Cells>
                    <Item1 Ref="28" ControlType="XRTableCell" Name="tableCell5" Weight="0.12003132746769832" Text="FIRST NAME" StyleName="GroupCaption2" />
                    <Item2 Ref="29" ControlType="XRTableCell" Name="tableCell6" Weight="0.87996873121995189" StyleName="GroupData2">
                      <ExpressionBindings>
                        <Item1 Ref="30" EventName="BeforePrint" PropertyName="Text" Expression="[first_name]" />
                      </ExpressionBindings>
                    </Item2>
                  </Cells>
                </Item1>
              </Rows>
            </Item1>
          </Controls>
        </Item3>
        <Item4 Ref="31" ControlType="DetailBand" Name="Detail1" HeightF="0" />
        <Item5 Ref="32" ControlType="GroupFooterBand" Name="GroupFooter1" GroupUnion="WithLastDetail" HeightF="6">
          <Controls>
            <Item1 Ref="33" ControlType="XRLabel" Name="label2" SizeF="650,2.08" LocationFloat="0,0" StyleName="GroupFooterBackground3" Borders="None">
              <StylePriority Ref="34" UseBorders="false" />
            </Item1>
          </Controls>
        </Item5>
      </Bands>
    </Item5>
    <Item6 Ref="35" ControlType="DetailReportBand" Name="DetailReport1" Level="1" DataMember="order_items" DataSource="#Ref-0">
      <Bands>
        <Item1 Ref="36" ControlType="DetailBand" Name="Detail2" HeightF="0" />
      </Bands>
    </Item6>
    <Item7 Ref="37" ControlType="DetailReportBand" Name="DetailReport2" Level="2" DataMember="orders" DataSource="#Ref-0">
      <Bands>
        <Item1 Ref="38" ControlType="DetailBand" Name="Detail3" HeightF="0" />
      </Bands>
    </Item7>
    <Item8 Ref="39" ControlType="DetailReportBand" Name="DetailReport3" Level="3" DataMember="products" DataSource="#Ref-0">
      <Bands>
        <Item1 Ref="40" ControlType="DetailBand" Name="Detail4" HeightF="0" />
      </Bands>
    </Item8>
  </Bands>
  <StyleSheet>
    <Item1 Ref="41" Name="Title" BorderStyle="Inset" Padding="6,6,0,0,100" Font="Arial, 14.25pt" ForeColor="255,75,75,75" BackColor="Transparent" BorderColor="Black" Sides="None" StringFormat="Near;Near;0;None;Character;GenericDefault" BorderWidthSerializable="1" />
    <Item2 Ref="42" Name="GroupCaption2" BorderStyle="Inset" Padding="6,2,0,0,100" Font="Arial, 8.25pt, style=Bold" ForeColor="255,228,228,228" BackColor="255,111,111,111" BorderColor="White" Sides="Bottom" StringFormat="Near;Center;0;None;Character;GenericDefault" TextAlignment="MiddleLeft" BorderWidthSerializable="2" />
    <Item3 Ref="43" Name="GroupData2" BorderStyle="Inset" Padding="6,2,0,0,100" Font="Arial, 8.25pt, style=Bold" ForeColor="White" BackColor="255,111,111,111" BorderColor="White" Sides="Bottom" StringFormat="Near;Center;0;None;Character;GenericDefault" TextAlignment="MiddleLeft" BorderWidthSerializable="2" />
    <Item4 Ref="44" Name="GroupFooterBackground3" BorderStyle="Inset" Padding="6,2,0,0,100" Font="Arial, 8.25pt, style=Bold" ForeColor="255,228,228,228" BackColor="255,131,131,131" BorderColor="White" Sides="Bottom" StringFormat="Near;Center;0;None;Character;GenericDefault" TextAlignment="MiddleLeft" BorderWidthSerializable="2" />
    <Item5 Ref="45" Name="PageInfo" BorderStyle="Inset" Padding="6,6,0,0,100" Font="Arial, 8.25pt, style=Bold" ForeColor="255,75,75,75" StringFormat="Near;Near;0;None;Character;GenericDefault" />
  </StyleSheet>
  <ComponentStorage>
    <Item1 Ref="0" ObjectType="DevExpress.DataAccess.Sql.SqlDataSource,DevExpress.DataAccess.v23.1" Name="sqlDataSource" Base64="PFNxbERhdGFTb3VyY2UgTmFtZT0ic3FsRGF0YVNvdXJjZSI+PENvbm5lY3Rpb24gTmFtZT0iY2xpZW50cyIgUHJvdmlkZXJLZXk9IlNRTGl0ZSI+PFBhcmFtZXRlcnM+PFBhcmFtZXRlciBOYW1lPSJkYXRhYmFzZSIgVmFsdWU9IkM6XFVzZXJzXFcwMDAzODYzMVxEZXNrdG9wXGNsaWVudHMuZGIiIC8+PFBhcmFtZXRlciBOYW1lPSJyZWFkIG9ubHkiIFZhbHVlPSIxIiAvPjxQYXJhbWV0ZXIgTmFtZT0iZ2VuZXJhdGVDb25uZWN0aW9uSGVscGVyIiBWYWx1ZT0iZmFsc2UiIC8+PC9QYXJhbWV0ZXJzPjwvQ29ubmVjdGlvbj48UXVlcnkgVHlwZT0iU2VsZWN0UXVlcnkiIE5hbWU9ImNsaWVudHMiPjxUYWJsZXM+PFRhYmxlIE5hbWU9ImNsaWVudHMiIC8+PC9UYWJsZXM+PENvbHVtbnM+PENvbHVtbiBUYWJsZT0iY2xpZW50cyIgTmFtZT0iY2xpZW50X2lkIiAvPjxDb2x1bW4gVGFibGU9ImNsaWVudHMiIE5hbWU9ImZpcnN0X25hbWUiIC8+PENvbHVtbiBUYWJsZT0iY2xpZW50cyIgTmFtZT0ibGFzdF9uYW1lIiAvPjxDb2x1bW4gVGFibGU9ImNsaWVudHMiIE5hbWU9ImVtYWlsIiAvPjwvQ29sdW1ucz48L1F1ZXJ5PjxRdWVyeSBUeXBlPSJTZWxlY3RRdWVyeSIgTmFtZT0ib3JkZXJfaXRlbXMiPjxUYWJsZXM+PFRhYmxlIE5hbWU9Im9yZGVyX2l0ZW1zIiAvPjwvVGFibGVzPjxDb2x1bW5zPjxDb2x1bW4gVGFibGU9Im9yZGVyX2l0ZW1zIiBOYW1lPSJvcmRlcl9pdGVtX2lkIiAvPjxDb2x1bW4gVGFibGU9Im9yZGVyX2l0ZW1zIiBOYW1lPSJvcmRlcl9pZCIgLz48Q29sdW1uIFRhYmxlPSJvcmRlcl9pdGVtcyIgTmFtZT0icHJvZHVjdF9pZCIgLz48Q29sdW1uIFRhYmxlPSJvcmRlcl9pdGVtcyIgTmFtZT0icXVhbnRpdHkiIC8+PC9Db2x1bW5zPjwvUXVlcnk+PFF1ZXJ5IFR5cGU9IlNlbGVjdFF1ZXJ5IiBOYW1lPSJvcmRlcnMiPjxUYWJsZXM+PFRhYmxlIE5hbWU9Im9yZGVycyIgLz48L1RhYmxlcz48Q29sdW1ucz48Q29sdW1uIFRhYmxlPSJvcmRlcnMiIE5hbWU9Im9yZGVyX2lkIiAvPjxDb2x1bW4gVGFibGU9Im9yZGVycyIgTmFtZT0iY2xpZW50X2lkIiAvPjwvQ29sdW1ucz48L1F1ZXJ5PjxRdWVyeSBUeXBlPSJTZWxlY3RRdWVyeSIgTmFtZT0icHJvZHVjdHMiPjxUYWJsZXM+PFRhYmxlIE5hbWU9InByb2R1Y3RzIiAvPjwvVGFibGVzPjxDb2x1bW5zPjxDb2x1bW4gVGFibGU9InByb2R1Y3RzIiBOYW1lPSJwcm9kdWN0X2lkIiAvPjxDb2x1bW4gVGFibGU9InByb2R1Y3RzIiBOYW1lPSJuYW1lIiAvPjxDb2x1bW4gVGFibGU9InByb2R1Y3RzIiBOYW1lPSJwcmljZSIgLz48L0NvbHVtbnM+PC9RdWVyeT48UmVzdWx0U2NoZW1hPjxEYXRhU2V0IE5hbWU9InNxbERhdGFTb3VyY2UiPjxWaWV3IE5hbWU9ImNsaWVudHMiPjxGaWVsZCBOYW1lPSJjbGllbnRfaWQiIFR5cGU9IkludDY0IiAvPjxGaWVsZCBOYW1lPSJmaXJzdF9uYW1lIiBUeXBlPSJTdHJpbmciIC8+PEZpZWxkIE5hbWU9Imxhc3RfbmFtZSIgVHlwZT0iU3RyaW5nIiAvPjxGaWVsZCBOYW1lPSJlbWFpbCIgVHlwZT0iU3RyaW5nIiAvPjwvVmlldz48VmlldyBOYW1lPSJvcmRlcl9pdGVtcyI+PEZpZWxkIE5hbWU9Im9yZGVyX2l0ZW1faWQiIFR5cGU9IkludDY0IiAvPjxGaWVsZCBOYW1lPSJvcmRlcl9pZCIgVHlwZT0iSW50NjQiIC8+PEZpZWxkIE5hbWU9InByb2R1Y3RfaWQiIFR5cGU9IkludDY0IiAvPjxGaWVsZCBOYW1lPSJxdWFudGl0eSIgVHlwZT0iSW50NjQiIC8+PC9WaWV3PjxWaWV3IE5hbWU9Im9yZGVycyI+PEZpZWxkIE5hbWU9Im9yZGVyX2lkIiBUeXBlPSJJbnQ2NCIgLz48RmllbGQgTmFtZT0iY2xpZW50X2lkIiBUeXBlPSJJbnQ2NCIgLz48L1ZpZXc+PFZpZXcgTmFtZT0icHJvZHVjdHMiPjxGaWVsZCBOYW1lPSJwcm9kdWN0X2lkIiBUeXBlPSJJbnQ2NCIgLz48RmllbGQgTmFtZT0ibmFtZSIgVHlwZT0iU3RyaW5nIiAvPjxGaWVsZCBOYW1lPSJwcmljZSIgVHlwZT0iRG91YmxlIiAvPjwvVmlldz48L0RhdGFTZXQ+PC9SZXN1bHRTY2hlbWE+PENvbm5lY3Rpb25PcHRpb25zIENsb3NlQ29ubmVjdGlvbj0idHJ1ZSIgLz48L1NxbERhdGFTb3VyY2U+" />
  </ComponentStorage>
</XtraReportsLayoutSerializer> --extension ".repx"
defVar --name databaseConnection --type DbConnection --output
defVar --name hasResult --type Boolean
defVar --name path --type String
defVar --name result --type String
defVar --name connectionString --type String
getSpecialFolder --folder "Desktop" path=value
setVar --name "${connectionString}" --value "Server=(localdb)\\mssqllocaldb;Database=automation;User Id=<user>;Password=<pass>"
sqlServerConnect --connectionstring "${connectionString}"
sqlExecute --connection ${databaseConnection} --statement "CREATE TABLE IF NOT EXISTS clients (client_id INTEGER PRIMARY KEY AUTOINCREMENT,first_name TEXT NOT NULL,last_name TEXT NOT NULL,email TEXT NOT NULL);"
sqlExecute --connection ${databaseConnection} --statement "CREATE TABLE IF NOT EXISTS products (product_id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT NOT NULL,price REAL NOT NULL);"
sqlExecute --connection ${databaseConnection} --statement "CREATE TABLE IF NOT EXISTS orders (order_id INTEGER PRIMARY KEY AUTOINCREMENT,client_id INTEGER,FOREIGN KEY(client_id) REFERENCES clients(client_id));"
sqlExecute --connection ${databaseConnection} --statement "CREATE TABLE IF NOT EXISTS order_items (order_item_id INTEGER PRIMARY KEY AUTOINCREMENT,order_id INTEGER,product_id INTEGER NOT NULL,quantity INTEGER NOT NULL,FOREIGN KEY(order_id) REFERENCES orders(order_id),FOREIGN KEY(product_id) REFERENCES products(product_id));"
sqlExecuteScalar --connection ${databaseConnection} --statement "SELECT COUNT(*) FROM orders;" result=value hasResult=hasresult
if --left "${hasResult}" --operator "Is_True" --negate
sqlExecute --connection ${databaseConnection} --statement "INSERT INTO clients (first_name, last_name, email)\r\nVALUES\r\n(\'John\', \'Doe\', \'john.doe@example.com\'),\r\n(\'Jane\', \'Doe\', \'jane.doe@example.com\'),\r\n(\'Peter\', \'Parker\', \'peter.parker@example.com\'),\r\n(\'Bruce\', \'Wayne\', \'bruce.wayne@example.com\'),\r\n(\'Clark\', \'Kent\', \'clark.kent@example.com\');"
sqlExecute --connection ${databaseConnection} --statement "INSERT INTO products (name, price)\r\nVALUES\r\n(\'Espresso\', 3.99),\r\n(\'Latte\', 4.99),\r\n(\'Capuccino\', 5.99),\r\n(\'Macchiato\', 4.50),\r\n(\'Americano\', 3.50),\r\n(\'Iced coffee\', 4.50),\r\n(\'Cold brew coffee\', 5.00),\r\n(\'Frappuccino\', 6.00),\r\n(\'Mocha\', 5.50),\r\n(\'White chocolate mocha\', 6.00);"
sqlExecute --connection ${databaseConnection} --statement "INSERT INTO orders (client_id)\r\nVALUES\r\n(1),\r\n(2),\r\n(3),\r\n(4),\r\n(5);"
sqlExecute --connection ${databaseConnection} --statement "INSERT INTO order_items (order_id, product_id, quantity)\r\nVALUES\r\n(1, 1, 2),\r\n(1, 2, 1),\r\n(2, 3, 3),\r\n(2, 4, 1),\r\n(3, 5, 2),\r\n(3, 6, 1),\r\n(4, 7, 3),\r\n(4, 8, 1),\r\n(5, 9, 2),\r\n(5, 10, 1);"
endIf
exportReport --format "Pdf" --watermark "None" --filepath "${path}\\myReport.pdf" --asset "${asset.report}" --mappings "{\"sqlDataSource\":\"${databaseConnection}\"}"