上一篇我们介绍了用书签的方式来填充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 的第三种方法 !