asp.net下用Aspose.Words for .NET动态生成word文档中的数据表格的方法

 更新时间:2010年04月14日 17:00:25   作者:  
导出word 文档,要求这个文档的格式不是固定的,用户可以随便的调整,导出内容中的数据表格列是动态的,例如要求导出姓名和性别,你就要导出这两列的数据,而且这个文档不是导出来之后再调整而是导出来后已经是调整过了的。

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);


我们来看看最后生成的效果:

到这里我们这一部分的功能就已经全部完成了。

也许这种方法并不是最好,如果朋友们有兴趣不妨研究研究,大家一起交流下。

附:Aspose.Words for NET 6.5 破解版下载地址

相关文章

  • C# 命名规则(挺不错的)

    C# 命名规则(挺不错的)

    我自己总结的一套命名规则,其实规则很重要,它是一种标准,可有可无,但有总会比无好,大家正在编码的同志仔细看看,给点改进意见。
    2009-02-02
  • 如何在.net6webapi中使用自动依赖注入

    如何在.net6webapi中使用自动依赖注入

    IOC/DI是一种设计模式,用于解耦组件之间的依赖关系,在传统的编程模式中,组件之间的依赖关系是硬编码在代码中的,这样会导致代码的耦合度很高,难以维护和发展,这篇文章主要介绍了如何在.net6webapi中实现自动依赖注入,需要的朋友可以参考下
    2023-06-06
  • C#处理Json的另外一种方式成功实践

    C#处理Json的另外一种方式成功实践

    通过C#调用js,用Js解析Json,并将返回值转换为C#数组,这种思路相信你没有用过吧,试试也无妨啊,感兴趣的你可千万不要走开啊
    2013-01-01
  • asp.net 设置GridView的选中行

    asp.net 设置GridView的选中行

    当点某行时,直接选中,然后移动方向键则切换不同的选中行; 如果直接按方向键,则从第一行开始标识
    2009-04-04
  • asp.net MVC利用ActionFilterAttribute过滤关键字的方法

    asp.net MVC利用ActionFilterAttribute过滤关键字的方法

    这篇文章主要介绍了asp.net MVC利用ActionFilterAttribute过滤关键字的方法,结合实例形式分析了ActionFilterAttribute过滤关键字的原理与相关实现技巧,需要的朋友可以参考下
    2016-03-03
  • 管理员登录设计(第7节)

    管理员登录设计(第7节)

    这篇文章主要内容是管理员登录设计,通过设计了解命名空间的概念,掌握命名控件的的构建和使用以及数据的读操作,需要的朋友可以参考下
    2015-08-08
  • ASP.NET Core MVC中过滤器工作原理介绍

    ASP.NET Core MVC中过滤器工作原理介绍

    这篇文章介绍了ASP.NET Core MVC中过滤器的工作原理,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-02-02
  • .NET命令行解析器示例程序(命令行选项功能)

    .NET命令行解析器示例程序(命令行选项功能)

    经常需要开发一下小工具,之前都是自己解析命令行参数,接触过动态语言社区以后,发现命令行解析有特定的模式和框架可以利用,本文介绍一个.NET 平台的类库CommandLineParser
    2013-11-11
  • asp.net web大文件上传带进度条实例代码

    asp.net web大文件上传带进度条实例代码

    web 大文件上传 带进度条
    2008-10-10
  • ASP.NET动态设置页面标题的方法详解

    ASP.NET动态设置页面标题的方法详解

    这篇文章介绍了ASP.NET动态设置页面标题的方法详解,有需要的朋友可以参考一下
    2013-07-07

最新评论