• <menu id="w2i4a"></menu>
  • logo E-iceblue中文文檔

    文檔首頁>>E-iceblue中文文檔>>在 Silverlight 中使用郵件合并

    在 Silverlight 中使用郵件合并


    我們已經(jīng)介紹了如何在 C# 和 VB.NET 中比較兩個(gè) Word 文檔。從 Spire.Doc V8.12.14 開始,它支持在結(jié)構(gòu)列表中獲取兩個(gè) Word 文檔之間的差異。本文將向您展示如何使用 Spire.Doc 通過比較兩個(gè) Word 文檔來獲取差異。

    Spire.Doc for.NET 最新下載

    介紹

    郵件合并通常用于批量打印報(bào)表,例如財(cái)務(wù)報(bào)表、工資單或成績單。合并后的文件可以通過電子郵件發(fā)送。

    在本文中,我將展示一種通過 Spire.Doc 生成郵件合并報(bào)告的方法。

    步驟

    我們需要完成以下 3 個(gè)步驟來生成我們的報(bào)告。

    • 創(chuàng)建郵件合并模板。
    • 從數(shù)據(jù)庫加載數(shù)據(jù)。
    • 將數(shù)據(jù)合并到模板中并保存。

    每個(gè)步驟都包含幾個(gè)子步驟,在#2 和#3 中我們需要編寫一些代碼。

    創(chuàng)建郵件合并模板

    模板是可重用的文檔。它呈現(xiàn)了我們報(bào)告的模式。我們可以修改它來更改我們的報(bào)告,而無需修改任何代碼。

    注意:在本節(jié)中,所有表均指 DataTable 實(shí)例,而不是數(shù)據(jù)庫中的物理表。

    首先,我們可以在 MS Word 或其他程序中創(chuàng)建模板。這是我們需要?jiǎng)?chuàng)建的模板。數(shù)據(jù)將填寫在紅方。

    郵件合并傳真

    其次,將 mail-merge-field 作為占位符插入紅塊中。郵件合并字段分為三種類型:

    • GeneralField 是一個(gè)通用的 Word 郵件合并字段。這是真實(shí)的數(shù)據(jù)字段,我們的數(shù)據(jù)將在合并過程中填寫。
    • TableField 是輔助郵件合并字段,用作多個(gè)相關(guān) GeneralField 和其他 TableField 的容器。所以它不是數(shù)據(jù)占位符,不會(huì)填寫任何數(shù)據(jù)。它由兩個(gè)特殊的郵件合并字段組成: TableStart: TableNameTableEnd:TableName。在合并過程中,同一個(gè) TableField 所包含的相關(guān) GeneralField 的數(shù)據(jù)將來自同一個(gè)數(shù)據(jù)表。
    • GroupField 也是輔助郵件合并字段。它可以包含多個(gè)相關(guān)的 GeneralFields 和 TableFields。它由兩個(gè)特殊的郵件合并字段組成: GroupStart: GroupName和 GroupEnd: GroupName。在合并過程中,將復(fù)制 GroupField 中包含的所有 Word 文檔元素。數(shù)據(jù)表中的一行有一個(gè)副本,該行中的數(shù)據(jù)將填充到副本中的字段中。如果該行有子數(shù)據(jù)表,則子數(shù)據(jù)表中的數(shù)據(jù)將填充到相應(yīng)的TableField中包含的字段中。如果子數(shù)據(jù)表有多個(gè)數(shù)據(jù)行,對(duì)應(yīng)的TableField也會(huì)被復(fù)制填充。我們需要在模板正文的頂部插入一個(gè)名為GroupStart:Order的郵件合并字段,并插入一個(gè)名為的郵件合并字段GroupEnd:OrderM在模板主體的底部。

    在此 Silverlight 應(yīng)用程序中,我們僅使用 GeneralField。如下圖所示。將郵件合并字段作為占位符插入紅塊。

    郵件合并傳真

    加載數(shù)據(jù)

    Spire.Doc 提供來自各種數(shù)據(jù)源的合并數(shù)據(jù)。該程序合并用戶填充的字符串?dāng)?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é)果

    Mail Merge Fax


    歡迎下載|體驗(yàn)更多E-iceblue產(chǎn)品

    如需獲取更多產(chǎn)品相關(guān)信息請(qǐng)咨詢慧都在線客服  


    掃碼咨詢


    添加微信 立即咨詢

    電話咨詢

    客服熱線
    023-68661681

    TOP
    三级成人熟女影院,欧美午夜成人精品视频,亚洲国产成人乱色在线观看,色中色成人论坛 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();