Mail Merge: Табличный отчет с регионами на C# и VB .Net


В этом примере показано, как сгенерировать табличный отчет с регионами, используя шаблон почтового слияния и XML-документ в качестве источника данных.

Здесь мы будем генерировать счета-фактуры для кондитерской. Для создания счетов-фактур нам понадобится только шаблон DOCX и XML-документ, содержащий заказы и кондитерские изделия.

1. Создайте шаблон в MS Word с полями слияния или используйте готовый файл «InvoiceTemplate.docx».

Записка. Если лист заказа должен начинаться с новой страницы, выполните следующие действия.

2. Затем мы создаем XML-документ, заполненный данными. Как вы можете видеть, имена тегов совпадают с именами полей слияния.
Это наш XML-документ: «Orders.xml»

Кстати, вы можете создать аналогичный XML-документ в своем приложении, используя Serialization. Ниже вы увидите демонстрационное WPF-приложение, в котором мы также использовали Serialization.

3. После выполнения метода слияния мы получим «Invoices.pdf» как результат. Полный код на C# и VB.Net находится внизу этой страницы.

Интересный: Чтобы воочию убедиться в этой функциональности, мы создали для вас полный WPF C# demo-app в котором показан полный процесс создания накладных в реальной кондитерской.

С помощью этого приложения вы можете создать новый XML-документ, заполненный заказами на торты, пирожные, хлебобулочные изделия и плюшки, а также сгенерировать счет-фактуру в форматах PDF, DOCX, RTF и HTML. Скачать WPF - Pastry Магазин, исходные тексты на C#(115 Kb).

Полный код

using System;
using System.Data;
using System.IO;
using SautinSoft.Document;

namespace Sample
{
    class Sample
    {
        static void Main(string[] args)
        {
            // Get your free 100-day key here:   
            // https://sautinsoft.com/start-for-free/

            TableReportWithRegions();
        }

        /// <summary>
        /// Generates a table report with regions using XML document as a data source.
        /// </summary>
        /// <remarks>
        /// See details at: https://www.sautinsoft.com/products/document/help/net/developer-guide/mail-merge-table-report-with-regions-net-csharp-vb.php
        /// </remarks>
        public static void TableReportWithRegions()
        {
            // Create the Dataset and read the XML.
            DataSet ds = new DataSet();

            ds.ReadXml(@"..\..\..\Orders.xml");

            // Load the template document.
            string templatePath = @"..\..\..\InvoiceTemplate.docx";

            DocumentCore dc = DocumentCore.Load(templatePath);

            // Execute the mail merge.
            dc.MailMerge.Execute(ds.Tables["Order"]);

            string resultPath = "Invoices.pdf";

            // Save the output to file
            dc.Save(resultPath);

            // Open the result for demonstration purposes.
            System.Diagnostics.Process.Start(new System.Diagnostics.ProcessStartInfo(resultPath) { UseShellExecute = true });
        }
    }
}

Download

Imports System
Imports System.Data
Imports System.IO
Imports SautinSoft.Document

Namespace Sample
    Friend Class Sample
        Shared Sub Main(ByVal args() As String)
            TableReportWithRegions()
        End Sub
        ''' Get your free 100-day key here:   
        ''' https://sautinsoft.com/start-for-free/
        ''' <summary>
        ''' Generates a table report with regions using XML document as a data source.
        ''' </summary>
        ''' <remarks>
        ''' See details at: https://www.sautinsoft.com/products/document/help/net/developer-guide/mail-merge-table-report-with-regions-net-csharp-vb.php
        ''' </remarks>
        Public Shared Sub TableReportWithRegions()
            ' Create the Dataset and read the XML.
            Dim ds As New DataSet()

            ds.ReadXml("..\..\..\Orders.xml")

            ' Load the template document.
            Dim templatePath As String = "..\..\..\InvoiceTemplate.docx"

            Dim dc As DocumentCore = DocumentCore.Load(templatePath)

            ' Execute the mail merge.
            dc.MailMerge.Execute(ds.Tables("Order"))

            Dim resultPath As String = "Invoices.pdf"

            ' Save the output to file
            dc.Save(resultPath)

            ' Open the result for demonstration purposes.
            System.Diagnostics.Process.Start(New System.Diagnostics.ProcessStartInfo(resultPath) With {.UseShellExecute = True})
        End Sub
    End Class
End Namespace

Download


Если вам нужен пример кода или у вас есть вопрос: напишите нам по адресу support@sautinsoft.com или спросите в онлайн-чате (правый нижний угол этой страницы) или используйте форму ниже:



Вопросы и предложения всегда приветствуются!

Мы разрабатываем компоненты .Net с 2002 года. Мы знаем форматы PDF, DOCX, RTF, HTML, XLSX и Images. Если вам нужна помощь в создании, изменении или преобразовании документов в различных форматах, мы можем вам помочь. Мы напишем для вас любой пример кода абсолютно бесплатно.