在asp.net中操作excel如何关闭excel的进程
在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
- 以下是一个完整的关闭excel进程的例子 2004-08-05 ycl111
- Excel单元格的合并 2004-10-25 21aspnet
- C#操作Excel 2006-06-07 alan_whg
- [C#]结束Excel的进程的方法 2005-01-22 ac669
- 操作EXCEL文件成功释放COM对象的代码 2004-12-20 mopeboy