当前位置: 首页 > 数据分析师 > 数据分析师实战技能 > 数据分析师数据分析 > Excel在.Net下驻留内存的解决方法

Excel在.Net下驻留内存的解决方法

发布时间:2020年09月29日 08:14:58 来源: 点击量:486

【摘要】Excel在 Net下驻留内存的解决方法这段时间在VS 2003 的WebForm 方式下对Excel 进行操作,遇到一个最为头疼的问题就是对Excel操作完毕后

Excel在.Net下驻留内存的解决方法

这段时间在VS 2003 的WebForm 方式下对Excel 进行操作,遇到一个最为头疼的问题就是对Excel操作完毕后Excel不能够正常关闭,系统退出后,Excel总是驻留在内存中。但是这段代码放到WinForm的程序中又没有问题。在网上进行了查找也没有找到有效可行的办法。经过无数次的尝试,终于解决如下:

  原来书写如下:

以下是引用片段:
  private Excel.Application m_app; 
  private Excel.Workbook m_workbook; 
  this.m_app = new Excel.ApplicationClass(); 
  this.m_app.DisplayAlerts = false; 
  this.m_workbook = this.m_app.Workbooks.Open(sFilePath, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value );

  修改后如下:

以下是引用片段:
  private Excel.Application m_app; 
  private Excel.Workbooks m_workbooks; 
  private Excel.Workbook m_workbook; 
  this.m_app = new Excel.ApplicationClass(); 
  this.m_app.DisplayAlerts = false; 
  m_workbooks = this.m_app.Workbooks; 
  this.m_workbook = this.m_workbooks.Open(sFilePath, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value );

  同样对Sheet的操作如下

  修改前如下:

以下是引用片段:
  Excel._Worksheet worksheet1 = null; 
  worksheet1 = (Excel._Worksheet) this.m_workbook.Worksheets.get_Item(sSheetName); 
  修改后如下: 
  Excel.Sheets sheets = null ; 
  Excel._Worksheet worksheet1 = null; 
  sheets = this.m_workbook.Worksheets; 
  worksheet1 = (Excel._Worksheet) sheets.get_Item(sSheetName);

  发现区别了么?原来Workbooks,Worksheets这两个类没有被实例化就直接使用了,造成该类不能够被回收。最终造成Excel在内存的驻留。

  最终以如下方式释放。

以下是引用片段:
  private void ReleaseAllRef(Object obj) 
  { 
  try 
  { 
  if (obj != null ) 
  { 
  while (Marshal.ReleaseComObject(obj) > 1); 
  } 
  } 
  finally 
  { 
  obj = null; 
  } 
  } 
  private void Release() 
  { 
  if (m_app != null ) 
  { 
  m_app.Quit() ; 
  } 
  ReleaseAllRef(m_workbook) ; 
  m_workbook = null ; 
  ReleaseAllRef(m_workbooks) ; 
  m_workbooks = null ; 
  ReleaseAllRef(m_app) ; 
  m_app = null ; 
  System.GC.Collect() ; 
  }

分享到: 编辑:wangmin

就业培训申请领取
您的姓名
您的电话
意向课程
点击领取

环球青藤

官方QQ

扫描上方二维码或点击一键加群,免费领取大礼包,加群暗号:青藤。 一键加群

绑定手机号

应《中华人民共和国网络安全法》加强实名认证机制要求,同时为更加全面的体验产品服务,烦请您绑定手机号.

预约成功

本直播为付费学员的直播课节

请您购买课程后再预约

环球青藤移动课堂APP 直播、听课。职达未来!

安卓版

下载

iPhone版

下载
环球青藤官方微信服务平台

刷题看课 APP下载

免费直播 一键购课

代报名等人工服务

课程咨询 学员服务 公众号

扫描关注微信公众号

APP

扫描下载APP

返回顶部