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

大家有帮助!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值