在 Silverlight 中使用邮件合并
我们已经介绍了如何在 C# 和 VB.NET 中比较两个 Word 文档。从 Spire.Doc V8.12.14 开始,它支持在结构列表中获取两个 Word 文档之间的差异。本文将向您展示如何使用 Spire.Doc 通过比较两个 Word 文档来获取差异。
介绍
邮件合并通常用于批量打印报表,例如财务报表、工资单或成绩单。合并后的文件可以通过电子邮件发送。
在本文中,我将展示一种通过 Spire.Doc 生成邮件合并报告的方法。
步骤
我们需要完成以下 3 个步骤来生成我们的报告。
- 创建邮件合并模板。
- 从数据库加载数据。
- 将数据合并到模板中并保存。
每个步骤都包含几个子步骤,在#2 和#3 中我们需要编写一些代码。
创建邮件合并模板
模板是可重用的文档。它呈现了我们报告的模式。我们可以修改它来更改我们的报告,而无需修改任何代码。
注意:在本节中,所有表均指 DataTable 实例,而不是数据库中的物理表。
首先,我们可以在 MS Word 或其他程序中创建模板。这是我们需要创建的模板。数据将填写在红方。
其次,将 mail-merge-field 作为占位符插入红块中。邮件合并字段分为三种类型:
- GeneralField 是一个通用的 Word 邮件合并字段。这是真实的数据字段,我们的数据将在合并过程中填写。
- TableField 是辅助邮件合并字段,用作多个相关 GeneralField 和其他 TableField 的容器。所以它不是数据占位符,不会填写任何数据。它由两个特殊的邮件合并字段组成: TableStart: TableName和TableEnd:TableName。在合并过程中,同一个 TableField 所包含的相关 GeneralField 的数据将来自同一个数据表。
- GroupField 也是辅助邮件合并字段。它可以包含多个相关的 GeneralFields 和 TableFields。它由两个特殊的邮件合并字段组成: GroupStart: GroupName和 GroupEnd: GroupName。在合并过程中,将复制 GroupField 中包含的所有 Word 文档元素。数据表中的一行有一个副本,该行中的数据将填充到副本中的字段中。如果该行有子数据表,则子数据表中的数据将填充到相应的TableField中包含的字段中。如果子数据表有多个数据行,对应的TableField也会被复制填充。我们需要在模板正文的顶部插入一个名为GroupStart:Order的邮件合并字段,并插入一个名为的邮件合并字段GroupEnd:OrderM在模板主体的底部。
在此 Silverlight 应用程序中,我们仅使用 GeneralField。如下图所示。将邮件合并字段作为占位符插入红块。
加载数据
Spire.Doc 提供来自各种数据源的合并数据。该程序合并用户填充的字符串数组中的数据。
using Spire.Doc; using System; using System.IO; namespace MailMerge { class Program { static void Main(string[] args) { String[] fieldNames = new String[] { "Contact Name", "Fax", "From", "Date", "Subject", "Content" }; DateTime faxDate = this.datePickerFaxDate.SelectedDate.HasValue ? this.datePickerFaxDate.SelectedDate.Value : DateTime.Now; String[] fieldValues = new String[] { this.textBoxTo.Text, this.textBoxFax.Text, this.textBoxFrom.Text, faxDate.ToShortDateString(), this.textBoxSubject.Text, this.textBoxContent.Text }; this.documentTemplate.MailMerge.Execute(fieldNames, fieldValues); bool? result = this.saveFileDialog.ShowDialog(); if (result.HasValue && result.Value) { using (Stream stream = this.saveFileDialog.OpenFile()) { //this.documentTemplate.SaveToStream(stream, FileFormat.Doc); this.documentTemplate.SaveToFile(stream, FileFormat.Doc); } } } } }
将数据合并到模板中并保存
在本节中,我们需要编写一些代码来调用 Spire.Doc 来合并我们的数据和模板。 this.documentTemplate.MailMerge.Execute(fieldNames, fieldValues); bool? result = this.saveFileDialog.ShowDialog(); if (result.HasValue && result.Value) { using (Stream stream = this.saveFileDialog.OpenFile()) { //this.documentTemplate.SaveToStream(stream, FileFormat.Doc); this.documentTemplate.SaveToFile(stream, FileFormat.Doc); } }
结果
欢迎下载|体验更多E-iceblue产品