导出Excel—之释放内存完美的解决办…

在导出Excel的时候,内存里面有时候会多出来很多Excel.exe,占用内存。

 

而如果在程序里面写一个杀掉Excel内存的方法,会把有用的打开的Excel也关掉。

 

而只要加一个判断就可以解决这一问题了。

 

//声明变量

  DateTime beforeTime;
  DateTime afterTime;

 

 

 

   //建立一个Excel.Application的新进程 同时给变量赋值
        beforeTime = DateTime.Now;

        Microsoft.Office.Interop.Excel.Application app = new Microsoft.Office.Interop.Excel.Application();

        afterTime = DateTime.Now;
 

 

 

//最后根据条件来关掉该关掉的Excel程序。

finally
        {
            Process[] myProcesses;
            DateTime startTime;
            myProcesses = Process.GetProcessesByName("Excel");

            //得不到Excel进程ID,暂时只能判断进程启动时间
            foreach(Process myProcess in myProcesses)
            {
                startTime = myProcess.StartTime;

                if(startTime > beforeTime && startTime < afterTime)
                {
                    myProcess.Kill();
                }
            }
          
        }

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值