做项目遇到一个需求,需要将用户生成的测试报告导出到word中保存。本篇文章只涉及如何获取视图页面(html源码)、使用NPOI将内容保存到Word。
分析需求需要做到两点就可以解决此问题。
1.由于使用的MVC技术,如何在控制器中提取得到视图页面。
2.将得到视图页面输出到word中。
我们先解决第一个技术点,C# MVC中如何在控制器中提取到视图页面。在控制器中使用下面方法搞定。
public static string GetViewHtml(ControllerContext context, string viewName, Object param)
{
if (string.IsNullOrEmpty(viewName))
viewName = context.RouteData.GetRequiredString("action");
using (var sw = new StringWriter())
{
ViewEngineResult viewResult = ViewEngines.Engines.FindPartialView(context, viewName);
var viewContext = new ViewContext(context,
viewResult.View,
context.Controller.ViewData,
context.Controller.TempData,
sw);
try
{
viewResult.View.Render(viewContext, sw);
}
catch (Exception ex)
{
throw;
}
return sw.GetStringBuilder().ToString();
}
}
解决第二个技术点,将得到视图页面输出到Word中。解决这个问题的时候我们先分析得出:在指定目录下新建一个文件文件类型是doc/docx,在将指定的内容输出到新建的文件中。下面我们将问题简单化在指定目录下新建一个Word。
这里我们需要用到NPOI的DLL 将内容保存到Word中。下面上干货。
public ActionResult CreateDoc(string htmlData)
{
XWPFDocument doc = new XWPFDocument(); //创建新的word文档
XWPFParagraph p1 = doc.CreateParagraph(); //向新文档中添加段落
p1.Alignment = ParagraphAlignment.CENTER; //段落对其方式为居中
XWPFRun r1 = p1.CreateRun(); //向该段落中添加文字
r1.SetText("页面视图");
XWPFParagraph p2 = doc.CreateParagraph();
p2.Alignment = ParagraphAlignment.LEFT;
XWPFRun r2 = p2.CreateRun();
r2.SetText(htmlData);
r2.FontSize = 14;//设置字体大小
r2.IsBold = false;//设置粗体
string path = "/upload/";
path += DateTime.Now.ToString("yyyyMM") + "/" + DateTime.Now.ToString("dd") + "/" +DateTime.Now.ToString("hhmmss");
string tempPath = path;
string fullpath = Server.MapPath(tempPath);//完成路径
//检查上传的物理路径是否存在,不存在则创建
if (!Directory.Exists(fullpath))
{
Directory.CreateDirectory(fullpath);
}
string allPath = fullpath + "/outDoc.docx";
FileStream sw = System.IO.File.Create(allPath); //...
doc.Write(sw); //...
sw.Close();
//将生成的文件返回浏览器
return File(allPath, "application/octet-stream", Url.Encode("测试文件.docx"));
}
最后结合调用。
视图主要代码:
<form action="@Url.Content("~/LSystem/Zg/Import/down")">
<input type="submit" value="下载到word数据" name="CreateDoc" />
</form>
控制器:
public ActionResult Import(string id)
{
if (id == "down")
{
var html = GetViewHtml(this.ControllerContext, "Import", null);
return CreateDoc(html);
}
else
{
return View("Import");
}
}
如果想将视图页面按照固定模版保存到word,需要对获取的数据进行逻辑处理。