有关使用 Aspose.Words for .NET来动态的生成word文档中的数据表
1、概述
最近项目中有一个这样的需求:导出word文档,要求这个文档的格式不是固定的,用户可以随便的调整,导出内容中的数据表格列是动态的,例如要求导出姓名和性别,你就要导出这两列的数据,而且这个文档不是导出来之后再调整而是导出来后已经是调整过了的。看到这里,您也许马上想到用模板导出!而且中自带有这个组件:,暂且可以满足需求吧。但这个组件也是有局限性的,例如客户端必须装office组件,而且编码复杂度高。最麻烦的需求是后面那个----动态的表格列头!下面就介绍如何使用 s for 来动态的生成word文档中的数据表格。
2、正文
s, 是Aspose“家族类库”之一。除这个以外,还有其他许多厉害的类库例如(操作PDF文件的类库)、h(操作 Flash文件的类库)、rt(操作报表的类库)等等,大家有兴趣的可以上官方网研究下。这些类库都包含两种语言,一种是java ,另一种是.这里主要是介绍s for 。s for 功能非常强大,您不需要安装office组件,都可以用这个来生成word文档。s支持 DOC,DOCX,OOXML,RTF格式,HTML格式,OpenDocument格式,PDF格式,和其他格式 。从下面图中,大家可以更加详细的了解s的架构。有一点忘了提,这套类库是收费的,在本文后面我会提供一个破解版的下载地址给大家的。
在介绍如何动态的生成的表格之前,我们看看这个类库是如何根据模板来生成值的:
首先,我们来建立一个 word模板: 。在文档中需要生成的数据地方建立一个书签,如图:
在这里大家可以看到,我们主要是通过BookMark来操作,做为动态的数据的'源。
下面我们来看看具体是怎么实现的:
复制代码 代码如下:
string tmppath = Server.MapPath("~/");
Document doc = new Document(tmppath); //载入模板
if (marks["name"] != null)
{
Bookmark mark = marks["name"];
= "张三公司";
}
("", , InWord, Response); //保存为doc,并打开
是不是很简单?好了,下面我们来看看文章开头所讲的如何动态生成word表格。
s对word文档对象中的操作。在生成表格上有点类似二维数组。还记得需求说的“表格列数由用户控制吗”,所以我们要在模板上定义一个含有表头的表格,这里要画出您数据表中可以显示的所有列头,这样做主要是考虑到用户可以自己去减少不需要显示列头。这里要注意,书签和列头文字的顺序不能颠倒,大家看下面代码就知道了。如下图:
灰色的部分就是bookmark了。s生成表格的原理就如同一个二维数组,也就是一个个单元格的去生成。我们来看看代码部分是如何实现的:
复制代码 代码如下:
DocumentBuilder builder = new DocumentBuilder(doc);
DataTable products = ata(); //数据源
int count = 0;
//记录要显示多少列
for (var i = 0; i < t; i++)
{
if (marks[mns[i]()] != null)
{
Bookmark mark = marks[mns[i]()];
= "";
count++;
}
}
listcolumn = new (count);
for (var i = 0; i < count; i++)
{
ToCell(0, 0, i, 0); //移动单元格
if (Type == markStart)
{
((entNode as BookmarkStart));
}
}
double width = h;//获取单元格宽度
ToBookmark("table"); //开始添加值
for (var m = 0; m < t; m++)
{
for (var i = 0; i < t; i++)
{
rtCell(); // 添加一个单元格
Style = le;
r = k;
h = width;
icalMerge = ;
e([m][listcolumn[i]]ring());
}
ow();
}
marks["table"] = ""; // 清掉标示
("", , InWord, onse);
我们来看看最后生成的效果:
到这里我们这一部分的功能就已经全部完成了。
也许这种方法并不是最好,如果朋友们有兴趣不妨研究研究,大家一起交流下。
-
关于Word将姓名按姓氏笔划排序的办法
在举办会议或者进行评比时,需要对相关的人员姓名按照姓氏笔划进行排序。首先,将需要排序的姓名写出来,每个姓名要占一行,即输入结束后需按“回车”换行,选中所有需要排序的姓名,执行“表格”菜单上的“排序”命令。在“排序文字”对话框里,“排序依据”项选择“段落数...
-
[荐]PPT模板
PPT模板1【教材分析】《伯牙绝弦》是人教版(实验版)国小语文第十一册第八组中的一篇课文。本组教材是以感受是以感受“艺术的魅力”为题来组合课文的。选编的四篇课文情真意切,文质兼美,从不同角度折射出艺术的魅力。本课文是一篇文言文,讲述了千古流传的饿高山流水...
-
Word设置文档页面的方法
通常在文档编辑之前我们需要对压面进行适当的'设置来保证达到我们的要求,那么怎么来设置页面呢?下面YJBYS小编就给大家详细介绍一下吧!1、预定义纸张,【页面布局】-【纸张大小】-【本身就定义好的纸张】(如A4、A3等)。2、自定义纸张,【页面布局】-【纸张大小】-...
-
excel时间函数与时间宏的录制
当前实时走动日期设置。当前日期设置函数=TODAY()。此为实时走动时间。、如果要加上星期,则右键/设置单元格格式/数字/日期,在类型栏中选择带星期的日期即可。Excel中快速插入日期与时间(非实时走动时间)在用Excel进行报表处理时,经常需要在表格的前端或者末尾输...
相关文章
- Diaspora Finance Powers Global Development美文欣赏
- Introduce two famous sport star英语作文
- A Letter to the Editor of a Newspaper英语四级作文
- Some words for this special occasion英文美文欣赏
- MySQL安装时出现current root password的解决方法
- Efforts Urged to Improve Womens Reproductive Health英语阅读
- 英语作文推荐:The Rewards of the Professions
- whats your plan for dragon boat festival英语作文
- aspose.words解决实现文档格的中创word方法
- Word Password Recovery破解密码的方法