在asp.net中操作excel如何关闭excel的进程

原创 2004年06月23日 09:55:00

在asp.net中操作excel经常会出现关闭不了后台excel进程的情况,本人最近搜索了一些资料,

已可以成功在程序中关闭excel,代码如下:

Excel.Application myExcel;
Excel._Workbook myWB;
Excel._Worksheet myWS = null;
Excel.Range myRange = null;

string filePath = Server.MapPath("//test//");
share.share myShClass = new share.share();
string strP = filePath + myShClass.getCurTimeAsID() + ".xls";
FileInfo file = new FileInfo(strP);

try
{
    myExcel = new Excel.Application();
    myExcel.Visible = false;
    myWB = myExcel.Workbooks.Add(true);
    myWS = (Excel._Worksheet)myWB.Sheets.Add(Type.Missing, Type.Missing, Type.Missing, Type.Missing);
    myWS = (Excel._Worksheet)myWB.Sheets[1];
    for(int i=0;i<arrHead.Count;i++)
    {
           myWS.Cells[1,i+1] = arrHead[i];
           myRange = (Excel.Range)myWS.Cells[1,i+1];
           FormatRange(19,ref myRange);
    }
    myWB.SaveAs(file.FullName, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Excel.XlSaveAsAccessMode.xlNoChange, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
}
catch(Exception e)
{
    Response.Write("初始化Excel文件出错,错误信息如下: "+e.ToString());
    return;
}
 
myWB.Close(false, Type.Missing, Type.Missing);
myExcel.Workbooks.Close();
myExcel.Quit();
System.Runtime.InteropServices.Marshal.ReleaseComObject(myRange);
System.Runtime.InteropServices.Marshal.ReleaseComObject(myWS);
System.Runtime.InteropServices.Marshal.ReleaseComObject(myWB);
System.Runtime.InteropServices.Marshal.ReleaseComObject(myExcel);
myWS = null;
myWB = null;
myExcel = null;
GC.Collect();

在写代码的过程中,按照上诉方法写还出现过excel没有关闭的情况,后来发现主要是

由于对其中的一个reference进行了两次单独的赋值,例如

myRange = (Excel.Range)myWS.Cells[1,1];
myRange = (Excel.Range)myWS.Cells[1,2];

上面这样写有时就会有问题,而改成

    for(int i=0;i<=2;i++)
    {
           myRange = (Excel.Range)myWS.Cells[1,i];
    }

就不会有问题了,虽然不太明白为什么,但是总归是能找到问题的出出了,

所以建议大家对excel的对象进行操作时尽量使用循环吧。

总的来说,asp.net对excel的操作还是有不少问题的,不知道因为什么原因就会

关闭不了excel的进程,而且对excel的操作还需要更改服务器的一些安全设置,

比较的麻烦,但是用以上方法基本上可以做到正常的关闭excel了,希望能对

大家有帮助!

ASP.NET导出Excel并将Excel进程关闭 (根据进程ID)

开发工作中经常遇到跟Excel打交道的地方,但在ASP.NET中使用完Excel后往往不能将其关闭,导致服务器上的Excel进程越来越多.本文介绍一个直接将进程KILL的方法,根据进程ID来KILL,...

.Net程序中如何彻底关闭Excel - 关闭进程外COM方法

在.Net中, 经常我们会利用Excel来展现数据. 我们知道此时, Excel做为一个进程外COM被激活. 可是却无法彻底关闭该进程. 这是什么原因呢?COM的生命周期依靠计数机制,只有当引用计数为...

ASP.NET操作Excel时出现

http://blog.eastmoney.com/fk/blog_120145559.html   问题描述: ASP.NET操作Excel时出现 System.UnauthorizedAc...

NPOI Asp.net操作Excel

原文:NPOI(1):Asp.net操作Excel先去官网:http://npoi.codeplex.com/下载需要引入dll(可以选择.net2.0或者.net4.0的dll),然后在网站中添加引...

Asp.net(C#)操作Excel的问题

     1.使用ADO.NET访问Excel?答:    首先代码如下。           //指定链接的数据源            string source = "F://XXX//XXX/...

asp.net(C#)套用模板操作Excel

当需要输出带大量公式的Excel文档的时候,在代码里写公式就太累了。   用设计好的Excel模板,复制一下,往里面添加数据比较省事。   模板 大气象   using Sys...

ASP.NET中Excel操作类

using System;  using System.Data;  using System.Configuration;  using System.Web;  using System.Web....

asp.net 操作Excel表数据导入到SQL Server数据库

代码全部贴出,主要是Excel表中的数据要和数据库中的数据类型要匹配。 这里Excel表中的字段是: 姓名、性别、班级、学号、初始密码 SQL Server表tb_Users中的字段是;...

asp.net中操作excel等不存在类型或命名空间名称Office

下午的一个Program中想导入一个EXCEL表,但是先后显示了 1.命名空间Microsoft中不存在类型或命名空间名称Office(是缺少程序集引用吗?) 2. 命名空间Microsoft...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在asp.net中操作excel如何关闭excel的进程
举报原因:
原因补充:

(最多只允许输入30个字)