Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.12.09;
Скачать: CL | DM;

Вниз

Microsoft Excel   Найти похожие ветки 

 
Jurden ©   (2002-11-28 14:36) [0]

Здраствуйте! Почему после выполнения следующей процедуры Excel висит в памяти (из-за чего если не виснет все, виснет сама программа)?

procedure T_Auto.sbExportClick(Sender: TObject);
var
Excel: Excel97.TExcelApplication;
WorkBook: Excel97.ExcelWorkBook;
WorkSheet: Excel97.ExcelWorkSheet;
begin
if (FileName <> "") then
begin
Excel := Excel97.TExcelApplication.Create(Self);
Excel.Connect;
WorkBook := (Excel.Workbooks.Open(FileName, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, False, 0));
WorkSheet := (WorkBook.Worksheets.Item[1] as Excel97._Worksheet);
// Работа с листом
WorkSheet := nil;
WorkBook := nil;
Excel.Quit;
FreeAndNil(Excel);
end
else
ShowMessage("Имя файла не выбрано!");
end;


 
sask ©   (2002-11-28 14:46) [1]

После работы с книгой: WorkBook.Close
и вместо Excel.Quit поставить Excel.Disconnect


 
sask ©   (2002-11-28 14:49) [2]

Причем все это в соответствующие try...finally


 
Jurden ©   (2002-11-28 15:14) [3]

Подправил, все равно висит.

procedure T_Auto.sbExportClick(Sender: TObject);
var
Excel: Excel97.TExcelApplication;
WorkBook: Excel97.ExcelWorkBook;
WorkSheet: Excel97.ExcelWorkSheet;
begin
if (FileName <> "") then
begin
Excel := Excel97.TExcelApplication.Create(Self);
Excel.Connect;
WorkBook := (Excel.Workbooks.Open(FileName, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, EmptyParam, False, 0));
WorkSheet := (WorkBook.Worksheets.Item[1] as Excel97._Worksheet);
// Работа с листом
WorkSheet := nil;
WorkBook.Close(False, FileNamem, EmptyParam, 0);
Excel.Disconnect;
FreeAndNil(Excel);
end
else
ShowMessage("Имя файла не выбрано!");
end;


 
Song ©   (2002-11-28 15:19) [4]

FreeAndNil(Excel); ???

Excel:=unAssigned;


 
Jurden ©   (2002-11-28 15:39) [5]

[Error] deAuto.pas(164): Incompatible types: "TExcelApplication" and "Variant"



Страницы: 1 вся ветка

Текущий архив: 2002.12.09;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.02 c
1-27956
Переяслов Григорий
2002-11-27 16:47
2002.12.09
Версия Windows


3-27832
UniDeMoN
2002-11-17 04:33
2002.12.09
создание собственной базы данных


1-27932
lscomp
2002-11-28 02:08
2002.12.09
Пустая строка


4-28350
Dark Simpson
2002-10-25 23:54
2002.12.09
RESIZING ОКНА


3-27805
DiamondA
2002-11-22 07:39
2002.12.09
InterBase and TerminalService??????????