欢迎来到千学网!
您现在的位置:首页 > 实用文 > 其他范文

Excel在.Net下驻留内存的解决方法EXCEL基本教程

时间:2022-09-05 08:36:49 其他范文 收藏本文 下载本文

下面就是小编给大家整理的Excel在.Net下驻留内存的解决方法EXCEL基本教程,本文共3篇,希望您能喜欢!

Excel在.Net下驻留内存的解决方法EXCEL基本教程

篇1:Excel在.Net下驻留内存的解决方法EXCEL基本教程

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

原来书写如下:

以下是引用片段:

privateExcel.Applicationm_app;

privateExcel.Workbookm_workbook;

this.m_app=newExcel.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);

修改后如下:

以下是引用片段:

privateExcel.Applicationm_app;

privateExcel.Workbooksm_workbooks;

privateExcel.Workbookm_workbook;

this.m_app=newExcel.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._Worksheetworksheet1=null;

worksheet1=(Excel._Worksheet)this.m_workbook.Worksheets.get_Item(sSheetName);

修改后如下:

Excel.Sheetssheets=null;

Excel._Worksheetworksheet1=null;

sheets=this.m_workbook.Worksheets;

worksheet1=(Excel._Worksheet)sheets.get_Item(sSheetName);

发现区别了么?原来Workbooks,Worksheets这两个类没有被实例化就直接使用了,造成该类不能够被回收,

最终造成Excel在内存的驻留。

最终以如下方式释放。以下是引用片段:

privatevoidReleaseAllRef(Objectobj)

{

try

{

if(obj!=null)

{

while(Marshal.ReleaseComObject(obj)>1);

}

}

finally

{

bj=null;

}

}

privatevoidRelease()

关 键 字:EXCEL

篇2:Excel在.Net下驻留内存的解决方法.net

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

这段时间在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

{

bj = 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() ;

}

【责任编辑:火凤凰 TEL:(010)68476606-8007】

原文转自:www.ltesting.net

篇3:在Excel中设置字符上、下标的方法EXCEL基本教程

和Word不同,Excel的“格式”菜单中没有直接设置字体格式的命令,格式设置存在于“单元格格式”对话框中,单元格中上下标的设置也需要在此对话框中进行,下面给大家简要介绍一下:

1.选中单元格中要设置为上、下标的字符,在选中字符上单击右键,选择快捷菜单中的“设置单元格格式”命令,如图1。

2.这种方式打开的“单元格格式”对话框,只有“字体”一个选项卡,在其左下方的“特殊效果”区域,有“上标”、“下标”两个复选项,选择其一,如图2。

3.单击“确定”按钮,选中字符即变为指定的上标或下标,

注意:对于文本字符,可按上述方法随意设置。但对于数字型字符,如此设置上下标,并不能起作用,必须先将此单元格格式设置为文本型,或在设置上下标后(编辑状态下)在单元格字符的最前面加一个半角单引号,这样才能完成正常设置。此外,设置上标后数字的数值大小并不改变,例如,10的二次方,计算时不会作为“100”,仍将按“102”进行计算。如图3。

关 键 字:EXCEL

在Excel中让填充更自如EXCEL基本教程

可以在Excel中使用的Office语音识别命令EXCEL基本教程

在gcc下模拟bfinuclinux的内存管理(2):所需要的文件及其更改

《Excel在.Net下驻留内存的解决方法EXCEL基本教程(共3篇).doc》
将本文的Word文档下载到电脑,方便收藏和打印
推荐度:
点击下载文档

文档为doc格式

最新推荐
猜你喜欢
点击下载本文文档