In-Table List with Filtering Grouping and Ordering in Word Processing Document

Note
In this article, we will use GroupDocs.Assembly to generate a In-Table List with Filtering, Grouping, and Ordering report in Word Processing Document format based on the use case: Working with a Business Case.
Note
The code uses some of the objects defined in The Business Layer.

In-Table List with Filtering, Grouping, and Ordering in Microsoft Word Document

Creating a In-Table List with Filtering, Grouping, and Ordering

Practising the following steps you can create In-Table List with Filtering, Grouping, and Ordering Template in MS Word 2013.

  1. Click the document where you want to add the table.
  2. Press the “Insert” tab to insert the table.
  3. Insert a 2x2 table.
  4. Save the template.

Reporting Requirement

As a report developer, you are required to represent customers’ orders information with the following key requirements:

  • Report must show each customer along with sum of prices of his orders.
  • It must represent all the information in tabular form.
  • Report must be generated in the Word Processing Document.

Adding Syntax to be evaluated by GroupDocs.Assembly Engine

 

Customer

Order Price

<<foreach [in orders

    .Where(c => c.OrderDate.Year == 2015)

    .GroupBy(c => c.Customer)

    .OrderBy(g => g.Key.CustomerName)]>><<[Key.CustomerName]>>

<<[Sum(c => c.Price)]>><</foreach>>

 

 

Tip
For detailed technical information about syntax, expressions and report generation by the engine, please visit: Working with GroupDocs.Assembly Engine

Download In-Table List with Filtering, Grouping, and Ordering Template

Please download the sample In-Table List with Filtering, Grouping, and Ordering document we created in this article:

Generating The Report

Custom Objects

// For complete examples and data files, please go to https://github.com/groupdocs-assembly/GroupDocs.Assembly-for-.NET
//Setting up source document template
const String strDocumentTemplate = "Word Templates/In-Table List with Filtering, Grouping, and Ordering.docx";
//Setting up destination document report
const String strDocumentReport = "Word Reports/In-Table List with Filtering, Grouping, and Ordering Report.docx";
try
{
//Instantiate DocumentAssembler class
DocumentAssembler assembler = new DocumentAssembler();
//Call AssembleDocument to generate In-Table List with Filtering, Grouping, and Ordering Report in document format
assembler.AssembleDocument(CommonUtilities.GetSourceDocument(strDocumentTemplate),
CommonUtilities.SetDestinationDocument(strDocumentReport),
new DataSourceInfo(DataLayer.GetOrdersData(), "orders"));
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}

Database Entities

// For complete examples and data files, please go to https://github.com/groupdocs-assembly/GroupDocs.Assembly-for-.NET
//Setting up source document template
const String strDocumentTemplate = "Word Templates/In-Table List with Filtering, Grouping, and Ordering_DB.docx";
//Setting up destination document report
const String strDocumentReport = "Word Reports/In-Table List with Filtering, Grouping, and Ordering_DB Report.docx";
try
{
//Instantiate DocumentAssembler class
DocumentAssembler assembler = new DocumentAssembler();
//Call AssembleDocument to generate In-Table List with Filtering, Grouping, and Ordering Report in document format
assembler.AssembleDocument(CommonUtilities.GetSourceDocument(strDocumentTemplate),
CommonUtilities.SetDestinationDocument(strDocumentReport),
new DataSourceInfo(DataLayer.GetOrdersDataDB(), "orders"));
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}

Using DataSet

// For complete examples and data files, please go to https://github.com/groupdocs-assembly/GroupDocs.Assembly-for-.NET
//Setting up source document template
const String strDocumentTemplate = "Word Templates/In-Table List with Filtering, Grouping, and Ordering_DB.docx";
//Setting up destination document report
const String strDocumentReport = "Word Reports/In-Table List with Filtering, Grouping, and Ordering_DT Report.docx";
try
{
//Instantiate DocumentAssembler class
DocumentAssembler assembler = new DocumentAssembler();
//Call AssembleDocument to generate In-Table List with Filtering, Grouping, and Ordering Report in document format
assembler.AssembleDocument(CommonUtilities.GetSourceDocument(strDocumentTemplate),
CommonUtilities.SetDestinationDocument(strDocumentReport),
new DataSourceInfo(DataLayer.GetCustomersAndOrdersDataDT()));
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}

Using XML DataSource

// For complete examples and data files, please go to https://github.com/groupdocs-assembly/GroupDocs.Assembly-for-.NET
//Setting up source document template
const String strDocumentTemplate = "Word Templates/In-Table List with Filtering, Grouping, and Ordering_XML.docx";
//Setting up destination document report
const String strDocumentReport = "Word Reports/In-Table List with Filtering, Grouping, and Ordering_XML Report.docx";
try
{
//Instantiate DocumentAssembler class
DocumentAssembler assembler = new DocumentAssembler();
//Call AssembleDocument to generate In-Table List with Filtering, Grouping, and Ordering Report in document format
assembler.AssembleDocument(CommonUtilities.GetSourceDocument(strDocumentTemplate),
CommonUtilities.SetDestinationDocument(strDocumentReport),
new DataSourceInfo(DataLayer.GetAllDataFromXML(), "ds"));
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}

Using JSON DataSource

// For complete examples and data files, please go to https://github.com/groupdocs-assembly/GroupDocs.Assembly-for-.NET
//setting up source
const String strDocumentTemplate = "Word Templates/In-Table List with Filtering, Grouping, and Ordering.docx";
//Setting up destination
const String strDocumentReport = "Word Reports/In-Table List with Filtering, Grouping, and Ordering_Json Report.docx";
try
{
//Instantiate DocumentAssembler class
DocumentAssembler assembler = new DocumentAssembler();//initialize object of DocumentAssembler class
//Call AssembleDocument to generate In-Table List with Filtering, Grouping, and Ordering report in document format
assembler.AssembleDocument(CommonUtilities.GetSourceDocument(strDocumentTemplate),
CommonUtilities.SetDestinationDocument(strDocumentReport),
new DataSourceInfo(DataLayer.GetCustomerOrderDataFromJson(), "orders"));
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}

In-Table List with Filtering, Grouping, and Ordering in OpenOffice Document

Creating the Template

OpenDocument Text (ODT) is a word processing document format which can be used as an alternative to Microsoft Word Document (DOC/DOCX) formats. Since ODT is not a Microsoft Proprietary format, there are multiple software (including Microsoft Office and Apache OpenOffice) available to create, open, edit and save this format. For more information on the available software to work with ODT, please visit wikipedia article.

In this topic, we ’ll not reinvent the wheel to recreate a template for generating an ‘In-Table List with Filtering, Grouping, and Ordering’ report in ODT format. Instead, we’ll save the existing template to ODT format using Microsoft Office. In order to achieve this; assuming you are using Microsoft Office 2010, please follow below steps:

  1. Open existing template we created in previous topic.
  2. Click “File” and select “Save As”.
  3. Select “OpenDocument Text” from “Save As Type” drop down.
  4. Click “Save”.

Download Template

Generating the report

Custom Objects

// For complete examples and data files, please go to https://github.com/groupdocs-assembly/GroupDocs.Assembly-for-.NET
//Setting up source open document template
const String strDocumentTemplate = "Word Templates/In-Table List with Filtering, Grouping, and Ordering_OpenDocument.odt";
//Setting up destination open document report
const String strDocumentReport = "Word Reports/In-Table List with Filtering, Grouping, and Ordering Report.odt";
try
{
//Instantiate DocumentAssembler class
DocumentAssembler assembler = new DocumentAssembler();
//Call AssembleDocument to generate In-Table List with Filtering, Grouping, and Ordering Report in open document format
assembler.AssembleDocument(CommonUtilities.GetSourceDocument(strDocumentTemplate),
CommonUtilities.SetDestinationDocument(strDocumentReport),
new DataSourceInfo(DataLayer.GetOrdersData(), "orders"));
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}

Database Entities

// For complete examples and data files, please go to https://github.com/groupdocs-assembly/GroupDocs.Assembly-for-.NET
//Setting up source open document template
const String strDocumentTemplate = "Word Templates/In-Table List with Filtering, Grouping, and Ordering_DB_OpenDocument.odt";
//Setting up destination open document report
const String strDocumentReport = "Word Reports/In-Table List with Filtering, Grouping, and Ordering_DB Report.odt";
try
{
//Instantiate DocumentAssembler class
DocumentAssembler assembler = new DocumentAssembler();
//Call AssembleDocument to generate In-Table List with Filtering, Grouping, and Ordering Report in open document format
assembler.AssembleDocument(CommonUtilities.GetSourceDocument(strDocumentTemplate),
CommonUtilities.SetDestinationDocument(strDocumentReport),
new DataSourceInfo(DataLayer.GetOrdersDataDB(), "orders"));
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}

Using DataSet

// For complete examples and data files, please go to https://github.com/groupdocs-assembly/GroupDocs.Assembly-for-.NET
//Setting up source open document template
const String strDocumentTemplate = "Word Templates/In-Table List with Filtering, Grouping, and Ordering_DB_OpenDocument.odt";
//Setting up destination open document report
const String strDocumentReport = "Word Reports/In-Table List with Filtering, Grouping, and Ordering_DT Report.odt";
try
{
//Instantiate DocumentAssembler class
DocumentAssembler assembler = new DocumentAssembler();
//Call AssembleDocument to generate In-Table List with Filtering, Grouping, and Ordering Report in open document format
assembler.AssembleDocument(CommonUtilities.GetSourceDocument(strDocumentTemplate),
CommonUtilities.SetDestinationDocument(strDocumentReport),
new DataSourceInfo(DataLayer.GetCustomersAndOrdersDataDT()));
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}

Using XML DataSource

// For complete examples and data files, please go to https://github.com/groupdocs-assembly/GroupDocs.Assembly-for-.NET
//Setting up source open document template
const String strDocumentTemplate = "Word Templates/In-Table List with Filtering, Grouping, and Ordering_XML_OpenDocument.odt";
//Setting up destination open document report
const String strDocumentReport = "Word Reports/In-Table List with Filtering, Grouping, and Ordering_XML Report.odt";
try
{
//Instantiate DocumentAssembler class
DocumentAssembler assembler = new DocumentAssembler();
//Call AssembleDocument to generate In-Table List with Filtering, Grouping, and Ordering Report in open document format
assembler.AssembleDocument(CommonUtilities.GetSourceDocument(strDocumentTemplate),
CommonUtilities.SetDestinationDocument(strDocumentReport),
new DataSourceInfo(DataLayer.GetAllDataFromXML(), "ds"));
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}

Using JSON DataSource

// For complete examples and data files, please go to https://github.com/groupdocs-assembly/GroupDocs.Assembly-for-.NET
//setting up source
const String strDocumentTemplate = "Word Templates/In-Table List with Filtering, Grouping, and Ordering_OpenDocument.odt";
//Setting up destination
const String strDocumentReport = "Word Reports/In-Table List with Filtering, Grouping, and Ordering_OpenDocument_Json Report.odt";
try
{
//Instantiate DocumentAssembler class
DocumentAssembler assembler = new DocumentAssembler();//initialize object of DocumentAssembler class
//Call AssembleDocument to generate In-Table List with Filtering, Grouping, and Ordering report in open document format
assembler.AssembleDocument(CommonUtilities.GetSourceDocument(strDocumentTemplate),
CommonUtilities.SetDestinationDocument(strDocumentReport),
new DataSourceInfo(DataLayer.GetCustomerOrderDataFromJson(), "orders"));
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}

ODT Template and Report in Apache OpenOffice

In order to check compatibility of ODT between Microsoft Office 2010 and Apache OpenOffice 4.1.2, we performed below tests:

  • We opened the ODT template created through Microsoft Office 2010 in Apache OpenOffice 4.1.2. The template opened successfully in Apache OpenOffice without any issues or formatting losses.
  • We opened the ODT report generated through GroupDocs.Assembly in Apache OpenOffice 4.1.2. The report opened successfully in Apache OpenOffice without any issues or formatting losses.