关键词:富文本编辑器 生成word 样式
为了解决标题中提出的问题,首选需要了解,在.net环境下读取数据库中的内容动态生成word至少有2种方式,【方式一】一种方式是在项目中添加引用,例如在“添加引用”对话框中的COM子tab中添加Microsoft Office 11.0 Object Library,然后再在代码中添加office相关的命名空间,使用word相关的对象读取模版文件并将文本写到模版提前设置好了标签的位置。这种方式是最初出现的方式,缺点在于:1.在服务器上需要按照office,否则在服务器环境想会因缺少库文件无法生成;2.需保持开发环境和服务器环境下office的版本一致,而服务器的环境相对稳定,软件更新频度不高,这一点对于那些喜欢追最新版本的开发者来说,可能会造成很多不必要的麻烦。【方式二】动态生成word文件的第二种方式是使用Open XML SDK,这种方法无需服务器安装office,是一种比较neat的方法,缺点是这种方式可能更适合新开发生成word的功能,对于方式一遗留代码的维护最好还是用方式一的方法。
用上面的方式将内容读入word和Excel等模版并不难。用富文本编辑器(最近比较fun KindEditor)进行文本编辑并控制样式,实际就是给文本加上html的标记,例如<strong></strong>等等,这时候将内容读入word并根据html tag的样式在word中显示同样的样式,需要一定技巧,弄不好容易直接显示html tag的文本。用方式二将富文本编辑器产生的内容生成到word中并显示对应的样式文章比较多,只要知道Open XML SDK这种开发方式就能搜到,因为操作的中间数据是统一的Office Open XML格式的,方式一的文章几乎没有,好不容易找到了一个英文的,思路也确实很简单,就是先把富文本编辑器产生的要读入word的文本保存到一个网页文件(.html文件中),然后在word中插入该文件,但给出的代码不太可用,仍然进行了一下午的摸索才得到行之有效的方式。下面是我的完整代码,每个参数都是设好的,可直接使用:
StreamWriter sw = new StreamWriter(System.Web.HttpContext.Current.Server.MapPath("~/temp.html"), false, Encoding.Default);
sw.Write("<html><head></head><body>");//temp.html中没有完整的html文件标记不行,没有的话会在word中显示html tag而不是样式,预先写入模版也行
sw.Write(dr["summary"].ToString());
sw.Write("</body></html>");
sw.Close();
object oFalse = false;
object oTrue = true;
object oMissing = System.Reflection.Missing.Value;
doc.Bookmarks.get_Item(ref bm[202]).Range.InsertFile(System.Web.HttpContext.Current.Server.MapPath("~/temp.html"), ref oMissing, ref oFalse, ref oTrue, ref oFalse);
下面是效果图:
(1)富文本编辑器中的文本
(2)生成的word文本