asp.net使用动态模版导出word
具体思路:
1.先制作Word模版,使用文本框+书签的方式来设计模版;
2.模版制作完之后,根据模版生成新文件,使用File.Copy方法,生成.doc格式新文件;
3.后台取得数据,参照网页渲染的方式标记数据流,方便之后的写入操作;
4.编辑新文件,根据程序中标记与书签的对应关系,利用类库中的方法来修改书签的内容,最后保存文件即可。
优点:
能够自定义元素的位置,方法也很简单易懂,如果只是表格之类的简单格式会很适用。
缺点:
灵活性不好,如果要套打的对象是网页,且不是表格形式的,还原程度不好,而且如果文字内容过多会出现超出文本框范围的情况。
操作过程&代码:
1)第一步,引入对应的程序集
如果不是使用第三方的类库的话,是不需要下载的,只要你的系统完整安装了office,你的系统程序集中就会带有操作Word的程序集。
首先,添加引用Microsoft.Office.Interop.Word,之后,在类中添加相对应的引用:
using MSWord = Microsoft.Office.Interop.Word; //这里重命名为MSWord,之后使用的时候就可以简写了
using System.IO;//要操作文件的话,要引用系统IO
using System.Reflection;
2)准备工作
MSWord.Application wordApp = new MSWord.Application();//word应用程序变量
MSWord.Document wordDoc;//word文档变量
string TemplateFile = @"D:\Model.doc"; //模版文件的路径,
string FileName = @"D:\" + DateTime.Now.ToString("yyyyMMddHHmmssffffff") + ".doc";//新文件的路径
3)拷贝模版生成新文件
File.Copy(TemplateFile, FileName);//首先要拷贝一份文件
object obj_FileName = FileName;//新建一个obj变量用于操作
4)设置操作类型,操作类型有很多中,这里要打开新文件,修改其中的内容
wordDoc = wordApp.Documents.Open(ref obj_FileName);//打开新文件,进行操作 wordDoc.Activate();//设置现在操作的文件
5)依据书签修改word内容
//循环书签,判断书签名称,并为其赋值
foreach (MSWord.Bookmark bm in wordDoc.Bookmarks)
{
if (bm.Name == "billno")
{
bm.Select();
bm.Range.Text = "2008";
}
if (bm.Name == "dated")
{
bm.Select();
bm.Range.Text = DateTime.Now.ToString();
}
}
6)关闭文件
wordDoc.SaveAs2(obj_FileName);//保存文件
wordDoc.Close();//关闭文档对象
wordApp.Quit();//关闭应用程序对象
7)杀进程,有的情况下,关闭Word文件会不成功,会残留很多word进程
System.Diagnostics.Process[] processes = System.Diagnostics.Process.GetProcessesByName("WINWORD");
foreach (System.Diagnostics.Process p in processes)
{
bool b = p.MainWindowTitle == "";
if (p.MainWindowTitle == "")
{
p.Kill();
}
}
8)下载
Response.Clear();
Response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(Path.GetFileName(FileName),
System.Text.Encoding.UTF8));
Response.ContentType = "application/msword";
Response.TransmitFile(FileName);
Response.Flush();
Response.End();
转自:https://www.cnblogs.com/jydeng/p/4398500.html
具体思路:
1.先制作Word模版,使用文本框+书签的方式来设计模版;
2.模版制作完之后,根据模版生成新文件,使用File.Copy方法,生成.doc格式新文件;
3.后台取得数据,参照网页渲染的方式标记数据流,方便之后的写入操作;
4.编辑新文件,根据程序中标记与书签的对应关系,利用类库中的方法来修改书签的内容,最后保存文件即可。
优点:
能够自定义元素的位置,方法也很简单易懂,如果只是表格之类的简单格式会很适用。
缺点:
灵活性不好,如果要套打的对象是网页,且不是表格形式的,还原程度不好,而且如果文字内容过多会出现超出文本框范围的情况。
操作过程&代码:
1)第一步,引入对应的程序集
如果不是使用第三方的类库的话,是不需要下载的,只要你的系统完整安装了office,你的系统程序集中就会带有操作Word的程序集。
首先,添加引用Microsoft.Office.Interop.Word,之后,在类中添加相对应的引用:
1 using MSWord = Microsoft.Office.Interop.Word; //这里重命名为MSWord,之后使用的时候就可以简写了
2 using System.IO;//要操作文件的话,要引用系统IO
3 using System.Reflection;
2)准备工作
1 MSWord.Application wordApp = new MSWord.Application();//word应用程序变量
2 MSWord.Document wordDoc;//word文档变量
3 string TemplateFile = @"D:\Model.doc"; //模版文件的路径,
4 string FileName = @"D:\" + DateTime.Now.ToString("yyyyMMddHHmmssffffff") + ".doc";//新文件的路径
3)拷贝模版生成新文件
1 File.Copy(TemplateFile, FileName);//首先要拷贝一份文件
2 object obj_FileName = FileName;//新建一个obj变量用于操作
4)设置操作类型,操作类型有很多中,这里要打开新文件,修改其中的内容
1 wordDoc = wordApp.Documents.Open(ref obj_FileName);//打开新文件,进行操作
2
3 wordDoc.Activate();//设置现在操作的文件
5)依据书签修改word内容

1 //循环书签,判断书签名称,并为其赋值
2 foreach (MSWord.Bookmark bm in wordDoc.Bookmarks)
3 {
4 if (bm.Name == "billno")
5 {
6 bm.Select();
7 bm.Range.Text = "2008";
8 }
9 if (bm.Name == "dated")
10 {
11 bm.Select();
12 bm.Range.Text = DateTime.Now.ToString();
13 }
14 }

6)关闭文件
1 wordDoc.SaveAs2(obj_FileName);//保存文件
2 wordDoc.Close();//关闭文档对象
3 wordApp.Quit();//关闭应用程序对象
7)杀进程,有的情况下,关闭Word文件会不成功,会残留很多word进程

1 System.Diagnostics.Process[] processes = System.Diagnostics.Process.GetProcessesByName("WINWORD");
2 foreach (System.Diagnostics.Process p in processes)
3 {
4 bool b = p.MainWindowTitle == "";
5 if (p.MainWindowTitle == "")
6 {
7 p.Kill();
8 }
9 }

asp.net使用动态模版导出word的更多相关文章
- PowerDesiger 15逆向生成工程E-R图及导出word表格
应用环境:win8(64位)+oracle10g(32位)服务端+PowerDesigner15 需求:oracle数据库中的表结构是web工程框架hibernate 自动生成,现需要将数据库中已有的 ...
- ASP.NET导出word实例
ASP.NET导出word实例 最近遇到一个题目就是如何在asp.net中将数据导出到word中,由于数据是动态的,所以需要在后台拼出想要的的格式,翻遍了网页找出了一个比较满意的代码,感谢那位高手.代 ...
- ASP.NET MVC 导出Word报表
最近要做MVC导出Word报表功能.查了查资料发现一个好用的插件就是Aspose.Word.这个插件也很有名气,也很好用. 1.首先就是引用该插件 2.填充Word模版 3.后台操作 private ...
- 【C#点滴记录】ASP.NET 使用C# 导出Word 和Excel
原文摘自 慧优米网,链接地址:http://huiyoumi.wang/upload/forum.php?mod=viewthread&tid=797&extra= 好了正文来了 今天 ...
- 在ASP.NET中将GridView数据导出到Word、Excel
在ASP.NET中将GridView数据导出到Word.Excel asp.net,导出gridview数据到Word,Excel,PDF #region Export to Word, Exce ...
- Asp.net通过模板(.dot/Html)导出Word,同时导出图片
一.Office组件导出Word(服务器配置麻烦) 需要引用Office的DLL,在下文的附件中,不同的Offic版本用的不一样,虽然高级版本可以兼容低级的,不过,还是统一版本最好 贴上核心代码(转载 ...
- Java使用IText(VM模版)导出PDF,IText导出word(二)
===============action=========================== //退款导出word public void exportWordTk() throws IOE ...
- java 导出word 并下载
记录一下导出操作 源码: /************ * 导出word 并下载 * @param id 房号记录编号 * ***********************/ @RequestMappin ...
- 导出Excel And 导出word
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default6.aspx. ...
随机推荐
- PAT B1029 旧键盘 (20 分)
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及实际被输入的文字,请你列出肯定坏掉的那些键. 输入格式: 输入在 2 行中分别给出应该输入的文字.以及 ...
- Android之网络摄像头
实现的功能就是两个手机在一个局域网内可以互相观看对方的摄像头图像,当然如果都是连接公网那么就能远程互看了,,,,和视频聊天差不多,,不过没有声音,,,,,,,, 源码是在网上找的(具体地址忘了,如有侵 ...
- phpstorm开发环境搭建流程
1.下载phpstorm 2.网上找注册码 phpstorm 8 license key Learn Programming===== LICENSE BEGIN =====63758-1204201 ...
- C++中的this和Python的self对比
Python,当实例对象调用函数(函数其实都是属于类空间的)的时候,系统会自动将对象本身传入 函数在定义时的第一个变量一般是self.(但self并不是关键字,用其他名字也可以) 定义 ...
- 【Java框架型项目从入门到装逼】第十三节 用户新增功能完结篇
这一节,我们把用户新增的功能继续做一个完善.首先,新增成功后,需要给前台返回一个信息,就是告诉浏览器,这次用户新增的操作到底是成功了呢,还是失败了呢?为此,我们需要专门引入一个结果类,里面只有两个属性 ...
- how2j 的shiro教程初探
教程案例里的mysql连接器只支持mysql,不支持mariadb,如果用的不是mysql,创建连接时会报错.
- [LOJ#6068]. 「2017 山东一轮集训 Day4」棋盘[费用流]
题意 题目链接 分析 考虑每个棋子对对应的横向纵向的极大区间的影响:记之前这个区间中的点数为 \(x\) ,那么此次多配对的数量即 \(x\) . 考虑费用流,\(S\rightarrow 横向区间 ...
- R绘图 第四篇:绘制箱图(ggplot2)
箱线图通过绘制观测数据的五数总括,即最小值.下四分位数.中位数.上四分位数以及最大值,描述了变量值的分布情况.箱线图能够显示出离群点(outlier),离群点也叫做异常值,通过箱线图能够很容易识别出数 ...
- 使用ClosedXML,读取到空行
最近项目中使用了ClosedXML.dll来处理Excel,在读取Excel的时候,用workSheet.Rows()获取Excel行数,默认读取Excel最大行数1048576 所以为了读取到不是空 ...
- Centos 7 安装mysql5.7.24二进制 版本
Mysql 二进制安装方法 下载mysql https://dev.mysql.com/downloads/mysql/ 1.解压包 tar xf mysql-5.7.24-linux-glibc2. ...