zoukankan      html  css  js  c++  java
  • C#简单实现动态数据生成Word文档并保存

    今天正好有人问我,怎么生成一个报表式的Word文档。

    就是文字的样式和位置相对固定不变,只是里面的内容从数据中读取。

    我觉得类似这种的一般用第三方报表来做比较简便。但既然要求了Word,只好硬着头皮来。

    网上的方法大多数都是从一个GridView或表中获得数据后向Word中添加一个表格。

    目标效果

    (图1)

    我们使用Word模板来实现,方法如下:

    1、首先需要向工程中的“引用”加入Word类库的引用(图2)。我是Office 2003。其他版本可能略有不同。在COM里面

    WORD DLL

    (图2)

    2、用Word设计一个模板文档(后缀名*.dot)。(图3)

    设计模板

    (图3)

    3、向模板中的需要显示动态内容的地方添加书签。具体方法是。光标落到欲插入内容的地方,选择菜单栏上的“插入”——〉“书签”(图4)

    添加“备注”的书签

    (图4)在“备注:”的后面添加一个书签,名字叫"beizhu"。书签名字不能以数字开头。

    4、完成全部书签的添加,依次应该是:

    位置 书签名
    备注右侧 beizhu
    姓名右侧单元格 name
    性别右侧单元格 sex
    生日右侧单元格 birthday
    籍贯右侧单元格 hometown

    5、保存这个已完成的模板到任意路径,例如 X:/template.dot

    6、在工程的窗体的类中添加引用的命名空间

    7、为了省事,直接在窗体的Load事件中加入以下代码。

     1 using System;
     2 using System.Collections.Generic;
     3 using System.ComponentModel;
     4 using System.Data;
     5 using System.Drawing;
     6 using System.Linq;
     7 using System.Text;
     8 using System.Windows.Forms;
     9 using Microsoft.Office.Interop.Word;
    10 
    11 namespace 生成word文档
    12 {
    13     public partial class Form1 : Form
    14     {
    15         public Form1()
    16         {
    17             InitializeComponent();
    18             Load += Form1_Load;
    19         }
    20 
    21         void Form1_Load(object sender, EventArgs e)
    22         {
    23             //**********************************************
    24             //来自博客http://blog.csdn.net/fujie724
    25             //**********************************************
    26             object oMissing = System.Reflection.Missing.Value;
    27             //创建一个Word应用程序实例
    28             Microsoft.Office.Interop.Word._Application oWord = new Microsoft.Office.Interop.Word.Application();
    29             //设置为不可见
    30             oWord.Visible = false;
    31             //模板文件地址,这里假设在X盘根目录
    32             object oTemplate = "d://template.dotx";
    33             //以模板为基础生成文档
    34             Microsoft.Office.Interop.Word._Document oDoc = oWord.Documents.Add(ref oTemplate, ref oMissing, ref oMissing, ref oMissing);
    35             //声明书签数组
    36             object[] oBookMark = new object[5];
    37             //赋值书签名
    38             oBookMark[0] = "beizhu";
    39             oBookMark[1] = "name";
    40             oBookMark[2] = "sex";
    41             oBookMark[3] = "birthday";
    42             oBookMark[4] = "hometown";
    43             //赋值任意数据到书签的位置
    44             oDoc.Bookmarks.get_Item(ref oBookMark[0]).Range.Text = "使用模板实现Word生成";
    45             oDoc.Bookmarks.get_Item(ref oBookMark[1]).Range.Text = "李四";
    46             oDoc.Bookmarks.get_Item(ref oBookMark[2]).Range.Text = "";
    47             oDoc.Bookmarks.get_Item(ref oBookMark[3]).Range.Text = "1987.06.07";
    48             oDoc.Bookmarks.get_Item(ref oBookMark[4]).Range.Text = "贺州";
    49             //弹出保存文件对话框,保存生成的Word
    50             SaveFileDialog sfd = new SaveFileDialog();
    51             sfd.Filter = "Word Document(*.doc)|*.doc";
    52             sfd.DefaultExt = "Word Document(*.doc)|*.doc";
    53             if (sfd.ShowDialog() == DialogResult.OK)
    54             {
    55                 object filename = sfd.FileName;
    56 
    57                 oDoc.SaveAs(ref filename, ref oMissing, ref oMissing, ref oMissing,
    58                 ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing,
    59                 ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing,
    60                 ref oMissing, ref oMissing);
    61                 oDoc.Close(ref oMissing, ref oMissing, ref oMissing);
    62                 //关闭word
    63                 oWord.Quit(ref oMissing, ref oMissing, ref oMissing);
    64             }
    65         }
    66     }
    67 }

    8、运行后直接弹出保存文件对话框(因为写在了Load事件里)。保存为Doc文档,打开发现效果如下(图5)

    最后效果

    (图5)

    至此,大功告成,文档中的内容正是我们所设定的。一个简单而又快捷的固定格式Word文档输出就完成了。

    希望对需要的朋友有帮助。

    以上完整教程为个人劳动成果,转载请注明出处。谢谢。

  • 相关阅读:
    MYSQL查询优化:profile功能
    MYSQL查询优化:调度和锁定
    SSL/TLS 协议详解
    flash传值给javascript,并在html页面输出
    【图片预加载】
    【minheight】最小高度 IE6、7、FF
    【图片等比缩放】CSS解决
    标签的空链接 href="#" 替换方案
    【实现三角】css的border属性解决方案
    【PNG在IE6下透明】——3种方案
  • 原文地址:https://www.cnblogs.com/tuqun/p/5083669.html
Copyright © 2011-2022 走看看