asp.net 导出到word 使用Aspose.Words for NET

1、 概述

  最近项目中有一个这样的需求:导 出word 文档,要求这个文档的格式不是固定的,用户可以随便的调整,导出内容中的数据表格列是动态的,例如要求导出姓名和性别,你就要导出这两列的数 据,而且这个文档不是导出来之后再调整而是导出来后已经是调整过了的。看到这里,您也许马上想到用模板导出!而且.NET中自带有这个组 件:Microsoft.Office.Interop.Word,暂且可以满足需求吧。但这个组件也是有局限性的,例如客户端必须装 office组 件,而且编码复杂度高。最麻烦的需求是后面那个----动态的表格列头!下面就介绍如何使用 Aspose.Words for .NET 来动态的生成word文档中的数据表格。

2、 正文

    Aspose.Words , 是Aspose“家族类库 ” 之一。除这个以外,还有其他许多厉害的类库例如Aspose.pdf(操作PDF文件的类库)、Aspose.Flash(操作 Flash文件的类库)、Aspose.report(操作报表的类库)等等,大家有兴趣的可以上官方网研究下。这些类库都包含两种语言,一种是 java ,另一种是.NET.这里主要是介绍 Aspose.Words for .NET 。Aspose.Words for .NET功能非常强大,您不需要安装office组件,都可以用这个来生成word文档。 Aspose.Words 支持 DOC,DOCX,OOXML,RTF格式,HTML格式,OpenDocument格式,PDF格式,和其他格式 。从下面图中,大家可以更加详细的了解Aspose.Words的架构。有一点忘了提,这套类库是收费的,在本文后面我会提供一个破解版的下载地址给大家的。

在介绍如何动态的生成的表格之前,我们看看这个类库是如何根据模板来生成值的:

首先,我们来建立一个 word 模板: template.doc 。在文档中需要生成的数据地方建立一个书签,如图:

 

 

在这里大家可以看到,我们主要是通过BookMark来操作,做为动态的数据的源。

下面我们来看看具体是怎么实现的:

string  tmppath  =  Server.MapPath( " ~/template.doc " );
Document doc  =   new  Document(tmppath);  // 载入模板
if  (doc.Range.Bookmarks[ " name " !=   null )
{
     Bookmark mark  =  doc.Range.Bookmarks[ " name " ];
     mark.Text  =   " 张三公司 " ;
}
doc.Save( " demo.doc " , SaveFormat.Doc, SaveType.OpenInWord, Response);   // 保存为doc,并打开

 是不是很简单?好了,下面我们来看看文章开头所讲的如何动态生成word表格。

Aspose.Words对word文档对象中的操作。在生成表格上有点类似二维 数组。还记得需求说的“表格列数由用户控制吗”,所以我们要在模板上定义一个含有表头的表格,这里要画出您数据表中可以显示的所有列头,这样做主要是考虑 到用户可以自己去减少不需要显示列头。这里要注意,书签和列头文字的顺序不能颠倒,大家看下面代码就知道了。如下图:

灰色的部分就是bookmark了。Aspose.Words生成表格的原理就如同一个二维数组,也就是一个个单元格的去生成。我们来看看代码部分是如何实现的:


DocumentBuilder builder 
=
 
new
 DocumentBuilder(doc);
DataTable products
= this .GetData(); // 数据源
int count = 0 ;
// 记录要显示多少列
for (var i = 0 ; i < products.Columns.Count; i )
{
if (doc.Range.Bookmarks[products.Columns[i].ColumnName.Trim()] != null )
{
Bookmark mark
= doc.Range.Bookmarks[products.Columns[i].ColumnName.Trim()];
mark.Text
= "" ;
count ;
}
}
System.Collections.Generic.List
< string > listcolumn = new System.Collections.Generic.List < string > (count);
for (var i = 0 ; i < count; i )
{
builder.MoveToCell(
0 , 0 , i, 0 ); // 移动单元格
if (builder.CurrentNode.NodeType == NodeType.BookmarkStart)
{
listcolumn.Add((builder.CurrentNode
as BookmarkStart).Name);
}
}
double width = builder.CellFormat.Width; // 获取单元格宽度
builder.MoveToBookmark( " table " ); // 开始添加值
for (var m = 0 ; m < products.Rows.Count; m )
{
for (var i = 0 ; i < listcolumn.Count; i )
{
builder.InsertCell();
// 添加一个单元格
builder.CellFormat.Borders.LineStyle = LineStyle.Single;
builder.CellFormat.Borders.Color
= System.Drawing.Color.Black;
builder.CellFormat.Width
= width;
builder.CellFormat.VerticalMerge
= Aspose.Words.Tables.CellMerge.None;
builder.Write(products.Rows[m][listcolumn[i]].ToString());
}
builder.EndRow();
}
doc.Range.Bookmarks[
" table " ].Text = "" ; // 清掉标示
doc.Save( " baojiadan.doc " , SaveFormat.Doc, SaveType.OpenInWord, page.Response);





下载地址http://www.165it.com/commons/2010/19162.html#download

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值