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

CSDN 推荐tag:asp.net excel runtime asp null 

在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了,希望能对

大家有帮助!



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=23299


[收藏到我的网摘]   gesnpt发表于 2004年06月23日 09:55:00

相关文章:
posted @ 2007-03-22 16:59  Benny Ng  阅读(1011)  评论(0编辑  收藏  举报