您的位置:首页 > 编程语言 > ASP

C# Aspose.Word 操作word文档【二】

2017-09-20 15:19 459 查看
上一篇我们介绍了用书签的方式来填充word中数据,今天介绍第二种方法操作word!

依旧是先自己建好word模板,然后这里就不需要插入书签了。

1、建立模板



能看到红色标示的区域依旧用到了书签,没事我们全删掉,如下图:



2、分析下为什么不用书签了,因为我的数据是动态生成的,而且不止一条,有很多条,所以这时候书签就起不到作用了,当然你也可以放在一个书签里,但是内容都在一个书签单元格里,会很恐怖的,而且不符合客户需求。

3、编写代码:

            string tempFile = Path.GetFullPath("resource/templete/项目建议书模板.doc").ToString();

            Document doc = new Document(tempFile);

            DocumentBuilder builder = new DocumentBuilder(doc);

            NodeCollection allTables = doc.GetChildNodes(NodeType.Table, true); //获取word中所有表格table

            Aspose.Words.Tables.Table table1 = allTables[0] as Aspose.Words.Tables.Table;//拿到第1个表格

            var roww1 = table1.Rows[14]; //获取第14行

            for (int i = 0; i < dt2.Rows.Count - 1; i++)    //dt2为数据源  datatable

            {

                var row1 = roww1.Clone(true);//复制第14行

                table1.Rows.Insert(14 + i, row1);//将复制的行插入当前行的上方

                builder.MoveToCell(0, 14 + i, 1, 0); //移动到第一个表格的第十四行第一个格子

                builder.Write(dt2.Rows[i]["MingCheng"].ToString()); //单元格填充文字

                builder.MoveToCell(0, 14 + i, 2, 0); //移动到第一个表格的第十四行第二个格子

                builder.Write(dt2.Rows[i]["GuiGeXingHao"].ToString()); //单元格填充文字

                builder.MoveToCell(0, 14 + i, 3, 0); //移动到第一个表格的第十四行第三个格子

                builder.Write(dt2.Rows[i]["DanWei"].ToString()); //单元格填充文字

                builder.MoveToCell(0, 14 + i, 4, 0); //移动到第一个表格的第十四行第四个格子

                builder.Write(dt2.Rows[i]["ShuLiang"].ToString()); //单元格填充文字                       

            }

            table1.Rows.RemoveAt(14 + dt2.Rows.Count - 1); //移除多余的空行

            doc.Save(tempFile);

            

4、效果图:



注意:下一篇介绍aspose.word操作table 的第三种方法 !
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: