一、Office组件导出Word(服务器配置麻烦)

需要引用Office的DLL,在下文的附件中,不同的Offic版本用的不一样,虽然高级版本可以兼容低级的,不过,还是统一版本最好

贴上核心代码(转载):

         Microsoft.Office.Interop.Word._Application appWord = new Microsoft.Office.Interop.Word.ApplicationClass();
Microsoft.Office.Interop.Word._Document docFile = null;
try
{
appWord.Visible = false;
object objTrue = true;
object objFalse = false;
object objTemplate = Server.MapPath(@"dot//123.dot");//模板路径
object objDocType = Microsoft.Office.Interop.Word.WdDocumentType.wdTypeDocument;
docFile = appWord.Documents.Add(ref objTemplate, ref objFalse, ref objDocType, ref objTrue);
//第一步生成word文档
//定义书签变量
object obDD_Name = "DD_Name";//姓 名
object obDD_Sex = "DD_Sex";//性 别
object obDD_Age = "DD_Age";//年龄
object obDD_Birthday = "DD_Birthday"; //出生年月
object obDD_Nation = "DD_Nation"; //民 族
object obDD_Native = "DD_Native"; //籍 贯 //第二步 读取数据,填充数据集
//SqlDataReader dr = XXXXX;//读取出来的数据集
//第三步 给书签赋值
//给书签赋值
docFile.Bookmarks.get_Item(ref obDD_Name).Range.Text = "姓 名"; //姓 名
docFile.Bookmarks.get_Item(ref obDD_Sex).Range.Text = "性 别";
docFile.Bookmarks.get_Item(ref obDD_Age).Range.Text = "年龄";        //存入图片
object objTrue = true;
docFile.Bookmarks.get_Item("Photo").Range.InlineShapes.AddPicture(HttpContext.Current.Server.MapPath(@"" + imgUrl), ref miss, ref objTrue, ref miss);
//第四步 生成word
DateTime dt = DateTime.Now;
object filename = Server.MapPath("dot//") + "表" + dt.Ticks.ToString() + ".doc";
object miss = System.Reflection.Missing.Value;
docFile.SaveAs(ref filename, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss);
object missingValue = Type.Missing;
object doNotSaveChanges = Microsoft.Office.Interop.Word.WdSaveOptions.wdDoNotSaveChanges;
docFile.Close(ref doNotSaveChanges, ref missingValue, ref missingValue);
appWord.Quit(ref miss, ref miss, ref miss);
docFile = null;
appWord = null;
}
catch (Exception ex)
{
//捕捉异常,如果出现异常则清空实例,退出word,同时释放资源
string aa = e.ToString();
object miss = System.Reflection.Missing.Value;
object missingValue = Type.Missing;
object doNotSaveChanges = Microsoft.Office.Interop.Word.WdSaveOptions.wdDoNotSaveChanges;
docFile.Close(ref doNotSaveChanges, ref missingValue, ref missingValue);
appWord.Quit(ref miss, ref miss, ref miss);
docFile = null;
appWord = null;
throw ex;
}

服务端生成后,附加简单的流下载代码:

                 string fileName = "表.doc";//客户端保存的文件名
string filePath = Server.MapPath("~/Download//Word//Table1.doc");//路径 //以字符流的形式下载文件
FileStream fs = new FileStream(filePath, FileMode.Open);
byte[] bytes = new byte[(int)fs.Length];
fs.Read(bytes, , bytes.Length);
fs.Close();
Response.ContentType = "application/octet-stream";
//通知浏览器下载文件而不是打开
Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8));
Response.BinaryWrite(bytes);
Response.Flush();
Response.End();

附上各个Office版本Dll库:

各个版本的microsoft.office.interop.word库.rar

二、通过htm模板导出(此方法简单,无需word组件支持!样式标准,不过有些缺陷,导出图片比较麻烦,而且,效果不好)

1、本地新建一个Word文档,然后编写文档格式,文字填充部分用{Title}等特殊标记表示,方便替换。

2、另存文档为网页格式(Htm、Html)。

3、将生成的模板网页放在网站目录下。

4、上代码:

 protected void Button1_Click(object sender, EventArgs e)
{
string strWord = ExprotMissionToWord(Server.MapPath("Temp.htm"));
Response.ContentEncoding = System.Text.Encoding.UTF7;
Response.ClearContent();
Response.ClearHeaders();
Response.AddHeader("content-disposition", "attachment;filename=magazineturn.doc");
Response.AddHeader("Content-type", "application");
Response.ContentType = "application/ms-html";
Response.ContentEncoding = System.Text.Encoding.Default;
Response.Write(strWord);
Response.Flush();
Response.Close();
} public string ExprotMissionToWord(string templatePath)
{
StringBuilder sb = new StringBuilder();
StreamReader sr = new StreamReader(templatePath, Encoding.Default);
sb.Append(sr.ReadToEnd());
sr.Close();
sb.Replace("{title}", "我是标题");
sb.Replace("{content} ", "我是正文");
return sb.ToString();
}

内容应该通俗易懂了,全部都是基础方法,就不细说了。

简单的说明一下,原理,是IO读取这个模板,然后替换掉设置的特殊字符,然后输出,ok!完成。

Asp.net通过模板(.dot/Html)导出Word,同时导出图片的更多相关文章

  1. C#通过模板导出Word(文字,表格,图片)

    C#通过模板导出Word(文字,表格,图片)   C#导出Word,Excel的方法有很多,这次因为公司的业务需求,需要导出内容丰富(文字,表格,图片)的报告,以前的方法不好使,所以寻找新的导出方法, ...

  2. php导出word(可包含图片)

    为大家介绍一个 php 生成 导出word(可包含图片)的代码,有需要的朋友可以参考下. 之前介绍过php生成word的例子,只是不能包含图片与链接. 今天 为大家介绍一个 php 生成 导出word ...

  3. word模板导出的几种方式:第二种:C#通过模板导出Word(文字,表格,图片) 占位符替换

    原文出处:https://www.cnblogs.com/ilefei/p/3508463.html 一:模板的创建   (注意文件后缀只能是.docx或.doct) 在需要位置 插入-文档部件-域, ...

  4. Spring MVC中使用POI导出Word

    内容绝大部分来源于网络 准备工作 准备[XwpfTUtil]工具类(来源于网络) 准备word模版 下载[XwpfTUtil]工具类 import org.apache.poi.xwpf.usermo ...

  5. ASP.NET导出word实例

    ASP.NET导出word实例 最近遇到一个题目就是如何在asp.net中将数据导出到word中,由于数据是动态的,所以需要在后台拼出想要的的格式,翻遍了网页找出了一个比较满意的代码,感谢那位高手.代 ...

  6. 【C#点滴记录】ASP.NET 使用C# 导出Word 和Excel

    原文摘自 慧优米网,链接地址:http://huiyoumi.wang/upload/forum.php?mod=viewthread&tid=797&extra= 好了正文来了 今天 ...

  7. .net core 使用NPOI填充Word模板导出Word

    最近工作用到在Word模板插入数据库数据,导出一个带数据的Word文件,想起来之前操作Word都是用微软提供的Microsoft.Office.Interop.Word,而在最新的..NET CORE ...

  8. 利用模板导出文件(二)之jacob利用word模板导出word文件(Java2word)

    https://blog.csdn.net/Fishroad/article/details/47951061?locationNum=2&fps=1 先下载jacob.jar包.解压后将ja ...

  9. java使用freemarker模板导出word(带有合并单元格)文档

    来自:https://blog.csdn.net/qq_33195578/article/details/73790283 前言:最近要做一个导出word功能,其实网上有很多的例子,但是我需要的是合并 ...

随机推荐

  1. less简介

    Less是一种动态的样式语言.Less扩展了CSS的动态行为,比如说,设置变量(Variables).混合书写模式(mixins).操作(operations)和功能(functions)等等,最棒的 ...

  2. Leetcode 144. Binary Tree Preorder Traversal

    参考例子:[8,3,1,6,4,7,10,14,13] 8,3,1 和 6,4 说明从root开始,沿着左臂向下寻找leaf 的过程中应该逐个将node.val push入ans. class Sol ...

  3. input-placeholder

    :-moz-placeholder { /* Mozilla Firefox 4 to 18 */ color: #f00; } ::-moz-placeholder { /* Mozilla Fir ...

  4. Alpha阶段发布说明

    Alpha版本功能介绍 机器法官功能已实现 这是我们统计了当下所有存在的狼人APP的共同缺点.也是用户最主要的痛点.现在所有已知存在的类似APP都不能提供法官功能,我们的APP将该功能革命性的自动实现 ...

  5. <<< Js中实现对字符串的截取

    1.函数split() 功能:使用一个指定的分隔符把一个字符串分割存储到数组 例:var Data = "1/234/5678/9"; var str = shuju.split( ...

  6. <<< Oracle序列的创建、修改、删除基本操作

    序列是一个命名的顺序编号生成器,可以被多个用户共享,类似sqlserver中的identity create sequence 序列名; //直接创建一个序列 CREATE SEQUENCE 序列名; ...

  7. redis之理解

    http://www.cnblogs.com/stephen-liu74/category/354125.html

  8. Example: Encoded SNMP Message - SNMP Tutorial

    30.11 Example Encoded SNMP Message The encoded form of ASN.1 uses variable-length fields to represen ...

  9. 谈谈java开发

    1.不要让未来的决策阻止你现在前进的方向 一步步列出每个步骤,那么对于现在应该专注于做什么,就一目了然了.你也不会浪费   时间去担心应该以后操心的事情. 2.不要让自信诱骗你忘事 当你去学习一个新概 ...

  10. (转)MySQL索引原理及慢查询优化

    转自美团技术博客,原文地址:http://tech.meituan.com/mysql-index.html 建索引的一些原则: 1.最左前缀匹配原则,非常重要的原则,mysql会一直向右匹配直到遇到 ...