C# asp.net 操作Word的前提配置和简单的方法
操作的前提:
1.要保证机器本身要安装OFFICE.
有时安装了Office,但是不能找到Microsoft Word 11.0(或者更高的版本) Object Library。那可能是因为在安装office的时候没有选在。net可编程性支持
此时只需要重新打开office安装文件-》添加或删除功能-》下一步-》在Microsoft Word下点选。net可编程性支持
以Office 2003为例

2.用VS打开一个asp.net网站,右键单击Bin ->添加引用,在COM中选择Microsoft Word 11.0(或者更高的版本) Object Library。点击确定后会在Bin文件夹中出现
Microsoft.Office.Interop.Word.dll
或者Interop.Word.dll

如果没有Bin文件夹,就右键根目录,选择添加ASP.NET文件->Bin
至此前提配置就完成了
编程部分:
添加引用
- using Microsoft.Office.Core;
- using Microsoft.Office.Interop;
- using Microsoft.Office.Interop.Word;
编程打开Word文件,和Word文件夹建立连接
- object oReadOnly = true;
- object oMissing = System.Reflection.Missing.Value;
- Word._Application oWord;
- Word._Document oDoc;
- oWord = new Word.Application();
- oWord.Visible = false;//只是为了方便观察,为true时,会显示一个打开的Word
- object fileName = System.Web.HttpContext.Current.Server.MapPath("~/Resultstemplate.doc").ToString();
- oDoc = oWord.Documents.Add(ref fileName, ref oMissing, ref oMissing, ref oMissing);
关闭和Word的连接
- oDoc.Close(ref missing, ref missing, ref missing);
- oWord.Quit(ref missing, ref missing, ref missing);
对Word中的表格的数据读取,并在网页中简单显示
- protected void PageFucword()
- {
- //object oMissing = System.Reflection.Missing.Value;
- //Word._Application oWord;
- //Word._Document oDoc;
- //oWord = new Word.Application();
- //oWord.Visible = true;
- //
- //oDoc = oWord.Documents.Add(ref fileName, ref oMissing,ref oMissing, ref oMissing);
- object oReadOnly = true;
- object oMissing = System.Reflection.Missing.Value;
- Word._Application oWord;
- Word._Document oDoc;
- oWord = new Word.Application();
- oWord.Visible = false;//只是为了方便观察
- object fileName = System.Web.HttpContext.Current.Server.MapPath("~/Resultstemplate.doc").ToString();
- oDoc = oWord.Documents.Add(ref fileName, ref oMissing, ref oMissing, ref oMissing);
- //MessageBox.Show(oDoc.Tables.Count.ToString());
- for (int tablePos = 1; tablePos <= oDoc.Tables.Count; tablePos++)
- {
- Word.Table nowTable = oDoc.Tables[tablePos];
- string tableMessage = string.Format("第{0}/{1}个表:\n", tablePos, oDoc.Tables.Count);
- // int i = 0;
- // foreach (Word.InlineShape shape in nowTable.Cell(28, 1).Range.InlineShapes)
- //{
- //直接读取图片
- //if (shape.Type == Word.WdInlineShapeType.wdInlineShapePicture)
- //{
- // //获取Word中的图片
- // byte[] img = (byte[])shape.Range.EnhMetaFileBits;
- // Bitmap bmp = new Bitmap(new System.IO.MemoryStream(img));
- // bmp.Save("c:\\pic" + i.ToString() + ".jpg ");
- //}
- //i++;
- //从剪切板上读取图片,还无法实现
- //if (shape.Type == Word.WdInlineShapeType.wdInlineShapePicture)
- //{
- // shape.Select();
- // oWord.Selection.Copy();
- // Image image = Clipboard.GetImage();
- // Bitmap bitmap = new Bitmap(image);
- // bitmap.Save("c:\\pic " + i.ToString() + ".jpg ");
- // i++;
- //}
- // }
- Table a = new Table();
- a.Attributes["border"] = "1";
- a.Attributes["width"] = "100%";
- for (int rowPos = 1; rowPos <= nowTable.Rows.Count; rowPos++)
- {
- TableRow rw = new TableRow();
- for (int columPos = 1; columPos <= nowTable.Rows[rowPos].Cells.Count; columPos++)
- {
- TableCell tc = new TableCell();
- if (nowTable.Columns.Count > nowTable.Rows[rowPos].Cells.Count)
- {
- tc.Attributes["colspan"] = nowTable.Columns.Count.ToString();
- tc.Attributes["align"] = "center";
- }
- string cell = nowTable.Cell(rowPos, columPos).Range.Text;
- if (cell.Contains(""))
- {
- int i = 0;
- foreach (Word.InlineShape shape in nowTable.Cell(rowPos, columPos).Range.InlineShapes)
- {
- //直接读取图片
- if (shape.Type == Word.WdInlineShapeType.wdInlineShapePicture)
- {
- System.Web.UI.WebControls.Image imgct = new System.Web.UI.WebControls.Image();
- //获取Word中的图片
- byte[] img = (byte[])shape.Range.EnhMetaFileBits;
- Bitmap bmp = new Bitmap(new System.IO.MemoryStream(img));
- string url = System.Web.HttpContext.Current.Server.MapPath("~/image/").ToString() + "pic" + i.ToString() + ".jpg ";//图片保存路径
- bmp.Save(url);
- imgct.ImageUrl = "~/image/" + "pic" + i.ToString() + ".jpg ";
- imgct.Attributes["width"] = "250px";
- tc.Controls.Add(imgct);
- tc.Wrap = true;
- }
- i++;
- }
- }
- else
- {
- cell = cell.Remove(cell.Length - 2, 2);
- if (cell == "") cell = "空";
- tc.Text = cell;
- //tableMessage += cell;
- //tableMessage = tableMessage.Remove(tableMessage.Length - 2, 2);//remove \r\a
- //tableMessage += "\t";
- }
- rw.Cells.Add(tc);
- }
- //tableMessage += "\n";
- a.Rows.Add(rw);
- }
- //Label1.Text = tableMessage;
- Page.Controls.Add(a);
- }
- }
通过标签Bookmark来读取数据
Bookmark bk;
bk.Range.Cells[1];//该值得到书签所在的单元格
- public bool FruitWordToSQL()
- {
- object oReadOnly = true;
- object oMissing = System.Reflection.Missing.Value;
- Word._Application oWord;
- Word._Document oDoc;
- oWord = new Word.Application();
- //oWord.Visible = false;//只是为了方便观察
- object fileName = System.Web.HttpContext.Current.Server.MapPath("~/Resultstemplate.doc").ToString();
- oDoc = oWord.Documents.Add(ref fileName, ref oMissing, ref oMissing, ref oMissing);
- System.Collections.IEnumerator enu = oWord.ActiveDocument.Bookmarks.GetEnumerator();
- Dictionary<string, string> map = new Dictionary<string, string>();//数据项(项名,项值)
- while (enu.MoveNext())
- {
- Word.Bookmark bk = (Word.Bookmark)enu.Current;
- string text = bk.Name.ToString();
- string value=bk.Range.Cells[1].Range.Text;//书签所在单元格的内容
- value = value.Remove(value.Length - 2);//去除单元格后的标记(/r/n)
- map.Add(text,value);
- }
- //对word的操作结束,关闭对word的控制
- oDoc.Close(ref oMissing, ref oMissing, ref oMissing);
- oWord.Quit(ref oMissing, ref oMissing, ref oMissing);
- //检验数据的格式及正确性
- KeyValuePair<bool,string> check=CheckData(map);
- if (check.Key == false)
- {
- //check.Value中所含的值为数据检验不符合标准的第一个数据的值
- return false;
- }
- //map中的数据插入到数据库的Fruit表中
- bool Inserted=InsertData(map);
- if (Inserted == false)//插入失败
- {
- //插入失败后的操作
- return false;
- }
- return true;
- }
C# asp.net 操作Word的前提配置和简单的方法的更多相关文章
- Asp.net操作Word文档,原来这么简单啊!
引用Word对象库文件 具体做法是打开菜单栏中的项目>添加引用>浏览,在打开的“选择组件”对话框中找到MSWORD.OLB后按确定即可引入此对象库文件,vs.net将会自动将库文件转化为 ...
- asp.net操作word的表格
近日开发中用户要求实现导出数据为Word,本来想使用html保存为word的实现,但因用户要求样式很高,使用html不好控制,并且导出中包括图片,使用页面导出时图片还是一个路径,不能把图片包括在wor ...
- ASP.NET操作Word的IIS权限配置
ASP.NET账号在默认情况下是没有权限操作Microsoft Office对象的,如果不进行权限的配置,代码会抛出类似以下的异常: 检索 COM 类工厂中 CLSID 为 {00024500-000 ...
- asp.net 操作word 权限
1.先安装office 2.在“DCOM配置”中,为IIS账号配置操作Word(其他Office对象也一样)的权限: 开始>运行>输入 dcomcnfg >确定 具体操作:“组件 ...
- Asp.Net 操作word 第二篇[推荐]
引言:前段时间有项目要用c#生成Word格式的计算报告,通过网络查找到很多内容,但是都很凌乱,于是自己决定将具体的步骤总结整理出来,以便于更好的交流和以后相似问题可以迅速的解决! 现通过具体的示例演示 ...
- asp.net 操作word
参考一:点击这里 参考二:点击这里 参考三:点击这里 using System; using System.Web.Security; using Microsoft.Office.Interop.W ...
- asp.net操作word 配置在IIS上出现的问题
异常: 检索 COM 类工厂中 CLSID 为 {000209FF-0000-0000-C000-000000000046} 的组件失败,原因是出现以下错误: 80070005 拒绝访问. (异常来自 ...
- 关于linux asp.net MVC网站中 httpHandlers配置无效的处理方法
近期有Jexus用户反映,在Linux ASP.NET MVC网站的Web.config中添加 httpHandlers 配置用于处理自定义类型,但是在运行中并没有产生预期的效果,服务器返回了404( ...
- asp.net操作GridView添删改查的两种方法 及 光棒效果
这部份小内容很想写下来了,因为是基础中的基础,但是近来用的比较少,又温习了一篇,发现有点陌生了,所以,还是写一下吧. 方法一:使用Gridview本身自带的事件处理,代码如下(注意:每次操作完都得重新 ...
随机推荐
- 云盾正常扫描云服务器的IP是什么
问题:云盾正常扫描云服务器的IP是什么? 解答:云盾扫描云服务器的的IP段固定为 42.120.145.0/24 110.75.105.0/24 110.75.185.0/24 110.75 ...
- javascript调用外部wpf的方法
今天因为项目需要在wpf嵌入web页面,然后在web页面调用wpf的方法,于是突击学习了一下,记下备忘.^_^ 1.wpf中新建一个类WpfForScriptingHelper namespace w ...
- CentOS添加RPMforge软件源
1.查看CentOS版本 cat /etc/redhat-release 2.查看系统位数 uname -i 3.下载rpm包 wget "rpm地址" CentOS 6: i68 ...
- Python设计模式——建造者模式
需求,画人物,要求画一个人的头,左手,右手,左脚,右脚和身体,画一个瘦子,一个胖子 不使用设计模式 #encoding=utf-8 __author__ = 'kevinlu1010@qq.com' ...
- 在VS中手工创建一个最简单的WPF程序
如果不用VS的WPF项目模板,如何手工创建一个WPF程序呢?我们来模仿WPF模板,创建一个最简单的WPF程序. 第一步:文件——新建——项目——空项目,创建一个空项目. 第二步:添加引用,Presen ...
- 如何在JS中获取Request方法
方法 function GetRequest() { var url = location.search; //获取url中"?"符后的字串 var theRequest = ne ...
- MVC-ActionResult解说
HttpNotFoundResult: 专门用来响应Http404找不到网页的错误,在System.Web.Mvc.Controller类别中内建了一个HttpNotFound()方法,可以很方便的回 ...
- Mac操作系统常用快捷键
复制:cmd+c 粘贴:cmd+v 剪切:先cmd+c,再cmd+opt+v 显示桌面:cmd+F3 切换输入法:cmd+space 打开Spotlight:ctrl+s ...
- POj 2186 Popular Cows[连通分量]
题目大意:给出N头牛,有M种关系u, v.代表u牛崇拜v牛.要求找出有多少头牛被所有牛崇拜着题目链接:http://poj.org/problem?id=2186解题思路:1>求出强连通分量,标 ...
- 利用ZABBIX的RPC-JSON作API扩展应用示例
计划将ZABBIX的一些状态可以在另一个应用的显示GRAPH及链接. 故而在网上找了几个文档,作了一个测试. https://www.zabbix.com/documentation/2.4/manu ...