В этом примере показано, как сгенерировать табличный отчет с регионами, используя шаблон почтового слияния и 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 });
}
}
}
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
Если вам нужен пример кода или у вас есть вопрос: напишите нам по адресу support@sautinsoft.ru или спросите в онлайн-чате (правый нижний угол этой страницы) или используйте форму ниже: