在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
转自:http://www.codesky.net/article/doc/201004/20100417061062.htm 最近项目中有一个这样的需求:导出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的架构。有一点忘了提,这套类库是收费的,在本文后面我会提供一个破解版的下载地址给大家的。
复制代码 代码如下:
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,并打开
复制代码 代码如下:
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);
|
请发表评论