今天工作中遇到了导出Word文档的问题,但是在搜索Aspose.Words 导出Word文档时发现网上的方法都是有头没尾的,有的只有一小段实例,让人看着摸不着头脑。借着https://www.cnblogs.com/cracker/archive/2012/07/21/AspnetExportWord.html这篇文章,把功能给做了出来,在此做个笔记。
利用Aspose.Words导出Word文档最重要的就是模板的建立。
模板设计的方法如下:
1.先建立好模板

2.在模板中插入 域 来使数据可以正确被替换。TableStart:All 表示表中所有的绑定数据从这个地方开始,必须要有TableEnd:All做为结束。 表格中循环部分的数据则是由TableStart:Item列名,列名TableEnd:Item结束 ,中间部分则只需要列名即可
在模板中插入域的方法如下:(office2016版本)
①:位置 :插入–文档部件–域

②: 域 中类型选择邮件合并、域名选择MergeField,然后在右边③域名中输入绑定的名称。到此模板建立就完成了。

接下来的代码部分:
public KeyValuePair<string, byte[]> DownWord(int sysNo)
{
var path = $"{hostingEnvironment.ContentRootPath}\XXXX.doc";
if (!File.Exists(path))
{
throw new FriendlyException("文件不存在");
}
var doc = new Aspose.Words.Document(path);
//ds指DataSet,已经组装好的DataSet
//利用ds数据替换模板中的数据
doc.MailMerge.ExecuteWithRegions(ds);
byte[] content = null;
using (var ms = new MemoryStream())
{
doc.Save(ms, Aspose.Words.SaveFormat.Doc);
content = ms.GetBuffer();
}
return new KeyValuePair<string, byte[]>(string.Format("{0}_{1}.doc", "xxxx导出", DateTime.Now.ToString("yyyy_MM_dd")), content);
}
组装数据的方法
private DataSet GetOneDs(MeetingModel model, List<C2MeetingSignModel> emps)
{
DataTable dt1 = new DataTable("All");//对应列表的中的 TableStart:All
dt1.Columns.Add("meetingDate");
dt1.Columns.Add("applyEmployeeName");
dt1.Columns.Add("meetingTitle");
dt1.Columns.Add("applyDeptName");
dt1.Columns.Add("meetingName");
DataRow dr1 = dt1.NewRow();
dr1["meetingDate"] = model.ApplyBeginTime.Value.ToString("yyyy-MM-dd HH:mm:ss") + "至" + model.ApplyEndTime.Value.ToString("yyyy-MM-dd HH:mm:ss");
dr1["applyEmployeeName"] = model.ApplyEmployeeName;//
dr1["meetingTitle"] = model.MeetingTitle;//
dr1["applyDeptName"] = model.ApplyDeptName;//
dr1["meetingName"] = model.MeetingName;//
dt1.Rows.Add(dr1);
DataTable dt2 = new DataTable("Item");//对应列表的中的 TableStart:Item
dt2.Columns.Add("sort");
dt2.Columns.Add("DeptName");
dt2.Columns.Add("Name");
int sort = 0;
if (emps.Count <= 0)
{
//为了防止导出的时候导出了绑定的模板,如果导出的模板中没有数据会默认导出绑定模板
var row = dt2.NewRow();
row[0] = "";
row[1] = "";
row[2] = "";
dt2.Rows.Add(row);
}
else
{
foreach (var item in emps)
{
sort++;
var row = dt2.NewRow();
row[0] = sort;
row[1] = item.DeptName;
row[2] = item.EmpName;
dt2.Rows.Add(row);
}
}
DataSet ds = new DataSet();
ds.Tables.Add(dt1);
ds.Tables.Add(dt2);
return ds;
}
© 版权声明
文章版权归作者所有,未经允许请勿转载。
版权声明:
1、IT大王遵守相关法律法规,由于本站资源全部来源于网络程序/投稿,故资源量太大无法一一准确核实资源侵权的真实性;
2、出于传递信息之目的,故IT大王可能会误刊发损害或影响您的合法权益,请您积极与我们联系处理(所有内容不代表本站观点与立场);
3、因时间、精力有限,我们无法一一核实每一条消息的真实性,但我们会在发布之前尽最大努力来核实这些信息;
4、无论出于何种目的要求本站删除内容,您均需要提供根据国家版权局发布的示范格式
《要求删除或断开链接侵权网络内容的通知》:https://itdw.cn/ziliao/sfgs.pdf,
国家知识产权局《要求删除或断开链接侵权网络内容的通知》填写说明: http://www.ncac.gov.cn/chinacopyright/contents/12227/342400.shtml
未按照国家知识产权局格式通知一律不予处理;请按照此通知格式填写发至本站的邮箱 wl6@163.com
1、IT大王遵守相关法律法规,由于本站资源全部来源于网络程序/投稿,故资源量太大无法一一准确核实资源侵权的真实性;
2、出于传递信息之目的,故IT大王可能会误刊发损害或影响您的合法权益,请您积极与我们联系处理(所有内容不代表本站观点与立场);
3、因时间、精力有限,我们无法一一核实每一条消息的真实性,但我们会在发布之前尽最大努力来核实这些信息;
4、无论出于何种目的要求本站删除内容,您均需要提供根据国家版权局发布的示范格式
《要求删除或断开链接侵权网络内容的通知》:https://itdw.cn/ziliao/sfgs.pdf,
国家知识产权局《要求删除或断开链接侵权网络内容的通知》填写说明: http://www.ncac.gov.cn/chinacopyright/contents/12227/342400.shtml
未按照国家知识产权局格式通知一律不予处理;请按照此通知格式填写发至本站的邮箱 wl6@163.com
相关文章
没有相关内容!