前言
在实际的项目需求中,我们不仅仅需要根据一个个字段将数据绑定到已经制作好的模板中,有时还需要根据特定的数据信息来动态的加载创建我们需要导出的文档。今天和大家分享的就是根据数据库查询时所返回信息个数动态的导出列表内容到我们制作好的Word模板中。
内容
都说一图抵千言,那就让我们通过图片来看看吧。首先这张图片就是我们需要提起那制造好的Word模板范例。与之前的模板相比我在这里加入了《TableStart:EduInfo》与《TableEnd:EduInfo》作为循环域的区间。如下图:
有了这样的两个域区间将会在我们有多条数据信息同时需要导出到列表时就可以自动一行行的创建添加新数据。并不会仅仅根据模板中固定的几个域来进行绑定。
下图为:当返回的信息为空时,导出的Word 文档。
下面来说说导出过程中的主要代码:
//通过tempPath获取到模板的路径
string tempPath = HttpContext.Current.Server.MapPath("~/template/Edu_Info.docx");
//通过outputPath设置我们将要导出的路径
string outputPath = HttpContext.Current.Server.MapPath("~/" + saveFold);
outputPath += "教育经历";
//实例化一个doc对象进行操作
Document doc = new Document(tempPath);
//将我们获得的DataTable类型的数据:EduDataTable放入doc方法中做处理
doc.MailMerge.ExecuteWithRegions(EduDataTable);
//合并模版,
doc.MailMerge.Execute(new[] { "PageCount" }, new object[] { doc.PageCount });
//保存文档到指定路径
doc.Save(outputPath);
小结
代码的实现过程中翻看了很多的文档和资料,看到各位高手们为了实现这样的一个功能所用的技术和设计令人叹服,今天将自己的这些小心得总结出来,希望可以帮到大家,荣幸与您分享!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/144268.html