加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

运行具有嵌套var访问权限的Delphi程序后,Excel.exe仍保持加载状

发布时间:2020-12-15 09:45:08 所属栏目:大数据 来源:网络整理
导读:我在 reasons why excel.exe remains loaded after running a delphi client automation program?问题上遇到了一个奇怪的问题.问题是更进一步. 我有用Delphi 7编写的代码并将其升级到XE2.这样做后我在XE2中遇到了同样的问题,虽然建议的解决方案在简单的测试
我在 reasons why excel.exe remains loaded after running a delphi client automation program?问题上遇到了一个奇怪的问题.问题是更进一步.

我有用Delphi 7编写的代码并将其升级到XE2.这样做后我在XE2中遇到了同样的问题,虽然建议的解决方案在简单的测试应用程序中工作,但只要我使用这些行,Excel.exe在程序退出后仍然加载:

fExcel: Variant; // Tried both as a field of a class and global variable

fExcel := CreateOleObject('Excel.Application');
try
  fExcel.Workbooks.Open(srcPathName);
  fExcel.DisplayAlerts := False;
  ...
  // Offending lines
  fExcel.ActiveWorkBook.ActiveSheet.Range[                                //
      fExcel.ActiveWorkBook.ActiveSheet.Cells[3,2],//
      fExcel.ActiveWorkBook.ActiveSheet.Cells[3+i,1+XL_PT_Tip_FieldCount] //
  ].Formula := VarArr;                                                    //
  ...
  fExcel.ActiveWorkBook.SaveAs(tgtPathName,-4143,'',False,False);
  fExcel.ActiveWorkBook.Close;
finally
  fExcel.Application.Quit;
  fExcel.Quit;
  fExcel := Unassigned;
end;

但是,如果我引入临时变量cl,ch:Variant并将以上替换为:

cl := fExcel.ActiveWorkBook.ActiveSheet.Cells[3,2];
ch := fExcel.ActiveWorkBook.ActiveSheet.Cells[3+i,1+XL_PT_Tip_FieldCount];
fExcel.ActiveWorkBook.ActiveSheet.Range[cl,ch].Formula := VarArr;

它神奇地开始工作,Excel.exe被妥善处理.

如果使用工作表变量,则会发生相同的情况,添加临时变量可以解决它:

sheetDynamicHb := fExcel.ActiveWorkBook.Sheets['Dynamics Hb'];
cl := sheetDynamicHb.Cells[52,2];
ch := sheetDynamicHb.Cells[52+i,2+3];
sheetDynamicHb.Range[cl,ch].Formula := VarArr;

以某种方式引入临时变量(cl,ch:Variant)就可以了.似乎嵌套的Excel变量访问做了一些奇怪的事情(使用ref计数?).我无法解释为什么会这样,但它确实如所描述的那样起作用并让我疯狂一点.

除了每次添加临时变量之外,是否存在这种行为和解决方案的原因?

根据要求:完整的计划:

unit Unit1;
interface
uses
  Winapi.Windows,Winapi.Messages,System.SysUtils,System.Variants,System.Classes,Vcl.Graphics,Vcl.Controls,Vcl.Forms,Vcl.Dialogs,Vcl.StdCtrls,ActiveX,ComObj;

type
  TForm1 = class(TForm)
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
var
  ex,VarArr,cl,ch: Variant;
begin
  ex := CreateOleObject('Excel.Application');
  try
    // Loading template XLS
    ex.Workbooks.Open('C:Documents and Settings...TemplateCommon.xls');
    ex.DisplayAlerts := False;

    //Selecting work sheet
    ex.ActiveWorkBook.Sheets['Sheet ABC'].Select;

    VarArr := VarArrayCreate([0,9,12],varVariant);

    // This code works fine    
    {cl := ex.ActiveWorkBook.ActiveSheet.Cells[3,2];
    ch := ex.ActiveWorkBook.ActiveSheet.Cells[3 + 9,2 + 12];
    ex.ActiveWorkBook.ActiveSheet.Range[cl,ch].Formula := VarArr;}

    // This code leaves Excel running
    ex.ActiveWorkBook.ActiveSheet.Range[
      ex.ActiveWorkBook.ActiveSheet.Cells[3,ex.ActiveWorkBook.ActiveSheet.Cells[3 + 9,2 + 12]
    ].Formula := VarArr;

    ex.ActiveWorkBook.SaveAs('C:Documents and Settings...out.xls',False);
    ex.ActiveWorkBook.Close;
  finally
    ex.Quit;
    ex := Unassigned;
  end;
end;

end.

实际程序要复杂得多,但即使在这个简单的测试用例中,也存在错误:

>如果是临时变量,Excel会立即处理掉.
>对于嵌套变量,只有在程序关闭时才会丢弃Excel,就像看起来有些东西可以引用它一样.

解决方法

按照创建变量的相反顺序处理excel的每个变量,然后excel对象正确配置.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读