AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Excel als Variant starten

Ein Thema von luckystar85 · begonnen am 9. Mär 2005 · letzter Beitrag vom 10. Mär 2005
Antwort Antwort
luckystar85

Registriert seit: 21. Dez 2004
Ort: Rostock
138 Beiträge
 
Delphi 2009 Professional
 
#1

Excel als Variant starten

  Alt 9. Mär 2005, 22:26
Ich möchte gerne Daten aus meinen Programm in Microsoft Excel exportieren. Dazu starte ich Excel wie folgt:

Code:var
Excel : Variant;
begin
try
Excel := GetActiveOleObject('Excel.Application');
except
try
Excel := CreateOleObject('Excel.Application');
except
MessageDlg('Microsoft© Excel konnte NICHT initialisiert werden!' + #13#10 +
'Systemfehler: ' + IntToStr(GetLastError) + #13#10 +
SysErrorMessage(GetLastError), mtWarning, [mbOk], 0);
exit;
end;
end;

Ich möchte das aber nicht mit Excelkomponenten machen.
Doch bei GetActiveOleObject bekommt mein Programm immer eine Exception, weil es das Objekt nicht gibt und erzeugt es dann im except.
Wenn ich aber das GetActiveOleObject weglasse und es immer wieder neu erzeuge habe ich nachher so viele Prozesse laufen.
Ist es auch möglich nur ein Prozess zu starten, ohne Exception?
Michael Klüber
Delphi ist was solides und besteht nicht wie C/C++ Quelltext nur aus Kommentaren.
  Mit Zitat antworten Zitat
Benutzerbild von toms
toms
(CodeLib-Manager)

Registriert seit: 10. Jun 2002
4.648 Beiträge
 
Delphi XE Professional
 
#2

Re: Excel als Variant starten

  Alt 9. Mär 2005, 22:48
Hallo,

Starte das Programm mal ausserhalb der Delphi IDE.
Dann kommt keine Exception.
Thomas
  Mit Zitat antworten Zitat
luckystar85

Registriert seit: 21. Dez 2004
Ort: Rostock
138 Beiträge
 
Delphi 2009 Professional
 
#3

Re: Excel als Variant starten

  Alt 9. Mär 2005, 22:52
Ja, das ist klar, wegen dem try except. Aber da ich das Programm meistens in der IDE starte, wegen debuggen und so, da nervt es dann immmer.
Michael Klüber
Delphi ist was solides und besteht nicht wie C/C++ Quelltext nur aus Kommentaren.
  Mit Zitat antworten Zitat
Benutzerbild von semo
semo

Registriert seit: 24. Apr 2004
755 Beiträge
 
Delphi 2010 Professional
 
#4

Re: Excel als Variant starten

  Alt 9. Mär 2005, 23:06
hallo? einmal f9 drücken und weiter gehts....
wenn dich als programmierer sowas nervt... ich weiß ja nicht.
  Mit Zitat antworten Zitat
luckystar85

Registriert seit: 21. Dez 2004
Ort: Rostock
138 Beiträge
 
Delphi 2009 Professional
 
#5

Re: Excel als Variant starten

  Alt 9. Mär 2005, 23:09
Na gut, ich dachte ich könnte das umgehen. Wenn es sich nicht ändern lässt.
Michael Klüber
Delphi ist was solides und besteht nicht wie C/C++ Quelltext nur aus Kommentaren.
  Mit Zitat antworten Zitat
Benutzerbild von Binärbaum
Binärbaum

Registriert seit: 19. Jan 2005
Ort: Elstra
764 Beiträge
 
Delphi 7 Enterprise
 
#6

Re: Excel als Variant starten

  Alt 10. Mär 2005, 00:26
Zitat von luckystar85:
Na gut, ich dachte ich könnte das umgehen. Wenn es sich nicht ändern lässt.
Ich glaube, dass ich irgendwann mal hier in der DP gelesen habe, dass man dieses Verhalten irgendwie abstellen kann. Allerdings weiß ich jetzt nicht mehr, wie.
Vielleicht hilft dir da die Suche weiter.

MfG
Binärbaum
There are exactly 10 kinds of people: those who understand binary, and those who don't.
---
"Software reift beim Kunden. Bei Hardware ist es anders: Hardware fault beim Kunden." - Rainer G. Spallek
  Mit Zitat antworten Zitat
padavan

Registriert seit: 12. Jan 2005
271 Beiträge
 
Delphi 7 Enterprise
 
#7

Re: Excel als Variant starten

  Alt 10. Mär 2005, 08:09
in den Debugger Optionen
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.202 Beiträge
 
Delphi 10.4 Sydney
 
#8

Re: Excel als Variant starten

  Alt 10. Mär 2005, 08:18
Delphi-Quellcode:
var
  Excel : Variant;
begin
  Excel := CreateOleObject('Excel.Application');
  try
    ... Dein Code ...
  finally
    FWorkBook.Close(SaveChanges:=False); <- Evtl geöffnete Workbooks (XLS-Dateien) auch wieder schließen
    Excel.Quit;
    Excel := UnAssigned;
  end;
end;
Bei Excel ist es entgegen der COM-gepflogenheiten auch immer noch nötig die Instanzen mit Quit zu beenden.
Ist zwar m.E. Blödsinn, da Excel aufgrund der Referenzzählung selbst feststellen könnte wann die Instanz beendet werden kann, aber es ist halt von M$. Da zählen die eigens aufgestellten (COM-)Regeln nichts.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
luckystar85

Registriert seit: 21. Dez 2004
Ort: Rostock
138 Beiträge
 
Delphi 2009 Professional
 
#9

Re: Excel als Variant starten

  Alt 10. Mär 2005, 12:54
Alles klar, danke schön das hilft mir weitr.
Michael Klüber
Delphi ist was solides und besteht nicht wie C/C++ Quelltext nur aus Kommentaren.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:33 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz