在 Silverlight 中使用郵件合并
我們已經(jīng)介紹了如何在 C# 和 VB.NET 中比較兩個 Word 文檔。從 Spire.Doc V8.12.14 開始,它支持在結(jié)構(gòu)列表中獲取兩個 Word 文檔之間的差異。本文將向您展示如何使用 Spire.Doc 通過比較兩個 Word 文檔來獲取差異。
介紹
郵件合并通常用于批量打印報表,例如財務(wù)報表、工資單或成績單。合并后的文件可以通過電子郵件發(fā)送。
在本文中,我將展示一種通過 Spire.Doc 生成郵件合并報告的方法。
步驟
我們需要完成以下 3 個步驟來生成我們的報告。
- 創(chuàng)建郵件合并模板。
- 從數(shù)據(jù)庫加載數(shù)據(jù)。
- 將數(shù)據(jù)合并到模板中并保存。
每個步驟都包含幾個子步驟,在#2 和#3 中我們需要編寫一些代碼。
創(chuàng)建郵件合并模板
模板是可重用的文檔。它呈現(xiàn)了我們報告的模式。我們可以修改它來更改我們的報告,而無需修改任何代碼。
注意:在本節(jié)中,所有表均指 DataTable 實例,而不是數(shù)據(jù)庫中的物理表。
首先,我們可以在 MS Word 或其他程序中創(chuàng)建模板。這是我們需要創(chuàng)建的模板。數(shù)據(jù)將填寫在紅方。
	 
 
其次,將 mail-merge-field 作為占位符插入紅塊中。郵件合并字段分為三種類型:
- GeneralField 是一個通用的 Word 郵件合并字段。這是真實的數(shù)據(jù)字段,我們的數(shù)據(jù)將在合并過程中填寫。
- TableField 是輔助郵件合并字段,用作多個相關(guān) GeneralField 和其他 TableField 的容器。所以它不是數(shù)據(jù)占位符,不會填寫任何數(shù)據(jù)。它由兩個特殊的郵件合并字段組成: TableStart: TableName和TableEnd:TableName。在合并過程中,同一個 TableField 所包含的相關(guān) GeneralField 的數(shù)據(jù)將來自同一個數(shù)據(jù)表。
- GroupField 也是輔助郵件合并字段。它可以包含多個相關(guān)的 GeneralFields 和 TableFields。它由兩個特殊的郵件合并字段組成: GroupStart: GroupName和 GroupEnd: GroupName。在合并過程中,將復制 GroupField 中包含的所有 Word 文檔元素。數(shù)據(jù)表中的一行有一個副本,該行中的數(shù)據(jù)將填充到副本中的字段中。如果該行有子數(shù)據(jù)表,則子數(shù)據(jù)表中的數(shù)據(jù)將填充到相應的TableField中包含的字段中。如果子數(shù)據(jù)表有多個數(shù)據(jù)行,對應的TableField也會被復制填充。我們需要在模板正文的頂部插入一個名為GroupStart:Order的郵件合并字段,并插入一個名為的郵件合并字段GroupEnd:OrderM在模板主體的底部。
在此 Silverlight 應用程序中,我們僅使用 GeneralField。如下圖所示。將郵件合并字段作為占位符插入紅塊。
	 
 
加載數(shù)據(jù)
Spire.Doc 提供來自各種數(shù)據(jù)源的合并數(shù)據(jù)。該程序合并用戶填充的字符串數(shù)組中的數(shù)據(jù)。
	 
 
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);
}
}
}
}
}
將數(shù)據(jù)合并到模板中并保存
在本節(jié)中,我們需要編寫一些代碼來調(diào)用 Spire.Doc 來合并我們的數(shù)據(jù)和模板。
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);
}
}
結(jié)果
	 
 
歡迎下載|體驗更多E-iceblue產(chǎn)品

 QQ交談
QQ交談 在線咨詢
在線咨詢 
                 
                
 渝公網(wǎng)安備
            50010702500608號
渝公網(wǎng)安備
            50010702500608號
             
            
 客服熱線
客服熱線