Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Sonstige Fragen zu Delphi (https://www.delphipraxis.net/19-sonstige-fragen-zu-delphi/)
-   -   Delphi Prüfen, ob Excel installiert ist (https://www.delphipraxis.net/197623-pruefen-ob-excel-installiert-ist.html)

MHaitz 22. Aug 2018 15:04

Prüfen, ob Excel installiert ist
 
Hallo allerseits,
ich greife von einem Delphi-Programm auf Excel zu. Um zu prüfen, ob Excel überhaupt installiert ist, verwende ich in einer try except Klausel CreateOleObject('Excel.Application'). Wenn Excel nicht installiert ist, wird ein Fehler ausgelöst und die Excel Funktionen des Programms gesperrt.

etwa folgendermassen:
FExcelIsInstalled := True;
try
try
tApp := CreateOleObject('Excel.Application');
if not VarIsNull(tApp) then begin
tApp.Visible := False;
tApp.Quit;
end else
FExcelIsInstalled := False;
except
FExcelIsInstalled := False;
end;
finally
tApp := UnAssigned;
end;

Leider scheint bereits der Aufruf CreateOleObject('Excel.Application') manchmal eine Access violation zu verursachen, wenn Excel nicht installiert ist.
Kennt jemand eine elegantere Methode, um die Installation von Excel abzufragen?

KodeZwerg 22. Aug 2018 15:10

AW: Prüfen, ob Excel installiert ist
 
Hilft Dir das weiter?
Delphi-Quellcode:
Function IsExcelInstalled : Boolean;
var
  ClassID: TCLSID;
  strOLEObject: string;
begin
  Result := False;
  strOLEObject := 'Excel.Application';
  if (CLSIDFromProgID(PWideChar(WideString(strOLEObject)), ClassID) = S_OK) then
    Result := True
   else
    Result := False;
end;

MHaitz 22. Aug 2018 15:19

AW: Prüfen, ob Excel installiert ist
 
Vielen Dank für die schnelle Antwort.

Das sieht schon mal gut aus. Werde es ausprobieren, und wenns Probleme gibt, mich wieder melden.

KodeZwerg 22. Aug 2018 17:55

AW: Prüfen, ob Excel installiert ist
 
Es sollte funktionieren. Ein wenig Google und siehe da, hab noch was auf SO gefunden was eventuell Dir nützlich sein könnte.
Delphi-Quellcode:
uses ComObj, ActiveX;

function IsObjectAvailable(const ClassName: string): Boolean;
var
  ClassID: TCLSID;
begin
  Result := Succeeded(CLSIDFromProgID(PWideChar(WideString(ClassName)),
    ClassID));
end;

function IsObjectActive(const ClassName: string): Boolean;
var
  ClassID: TCLSID;
  Unknown: IUnknown;
begin
  Result := False;
  if Succeeded(CLSIDFromProgID(PWideChar(WideString(ClassName)), ClassID)) then
    Result := Succeeded(GetActiveObject(ClassID, nil, Unknown));
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
  if IsObjectAvailable('Excel.Application') then
    ShowMessage('Excel is available');
  if IsObjectActive('Excel.Application') then
    ShowMessage('Excel is running');
end;

Chemiker 22. Aug 2018 22:33

AW: Prüfen, ob Excel installiert ist
 
Hallo,

oder einfacher:

Delphi-Quellcode:
procedure TForm1.Button2Click(Sender: TObject);
begin
  if Excel_Vorhanden() then
  begin
    ShowMessage(' Excel ist vorhanden');
  end
   else
  begin
    ShowMessage(' Excel ist nicht vorhanden');
  end;
end;

function TForm1.Excel_Vorhanden (): boolean;
var
  olevExcel: OleVariant;
begin
  Result:= TRUE;
  try
    olevExcel := GetActiveOleObject('Excel.Application');
  except
    try
      olevExcel := CreateOleObject('Excel.Application');
    except
      Result:= FALSE;
      exit;
    end;
  end;
end;


Bis bald Chemiker

KodeZwerg 22. Aug 2018 22:55

AW: Prüfen, ob Excel installiert ist
 
Deine Methode wirft sofort eine Exception wenn man kein Excel installiert hat.
Ich mag meine Variante mehr :wink:

Ps: Exception kommt nur wenn innnerhalb IDE ausgeführt.

Luckie 22. Aug 2018 23:20

AW: Prüfen, ob Excel installiert ist
 
Zitat:

Zitat von Chemiker (Beitrag 1411361)
Hallo,
Delphi-Quellcode:
procedure TForm1.Button2Click(Sender: TObject);
begin
  if Excel_Vorhanden() then
  begin
    ShowMessage(' Excel ist vorhanden');
  end
   else
  begin
    ShowMessage(' Excel ist nicht vorhanden');
  end;
end;

function TForm1.Excel_Vorhanden (): boolean;
var
  olevExcel: OleVariant;
begin
  Result:= TRUE;
  try
    olevExcel := GetActiveOleObject('Excel.Application');
  except
    try
      olevExcel := CreateOleObject('Excel.Application');
    except
      Result:= FALSE;
      exit;
    end;
  end;
end;

Warum bei einer einfachen True/False Abfrage eine Exception missbrauchen? Exceptions sind eigentlich dazu gedacht Fehler zu behandeln, die man nicht selbst beeinflussen kann. Netzwerkstecker wird gezogen, Festplatte voll, Diskette wird vom Benutzer ausgeworfen. Und die kein sinnvolles weiter Ausführen des Codes an der Stelle erlauben. Und du verschachtelst sogar noch zwei Exceptions.

OLDIE1950 23. Aug 2018 11:52

AW: Prüfen, ob Excel installiert ist
 
Kleiner Tipp:
http://www.tech-ecke.de/index_querei...lphi/excel.htm

Verbindungsaufbau zu Excel
Code:
var Excel: Variant;
...
try
   Excel := CreateOleObject('Excel.Application');
   Excel.visible := true;
except
   ShowMessage('Excel konnte nicht gestartet werden !');
end;
   Excel.DisplayAlerts:=False; // unterdrückt die Ausgabe Hinweisen von Excel
   Excel.Workbooks.Add; // um ein neues Sheet zu erstellen, ist demnach beim lesen eines vorhandenen Sheets nicht nötig!

   // hier folgen die eigentlichen Steuerbefehle...

VarClear(Excel); // Freigabe

p80286 23. Aug 2018 15:37

AW: Prüfen, ob Excel installiert ist
 
Zitat:

Zitat von Luckie (Beitrag 1411363)

Warum bei einer einfachen True/False Abfrage eine Exception missbrauchen? Exceptions sind eigentlich dazu gedacht Fehler zu behandeln, die man nicht selbst beeinflussen kann. Netzwerkstecker wird gezogen, Festplatte voll, Diskette wird vom Benutzer ausgeworfen. Und die kein sinnvolles weiter Ausführen des Codes an der Stelle erlauben. Und du verschachtelst sogar noch zwei Exceptions.

Und was wäre die Alternative?
Delphi-Quellcode:
olevExcel := GetActiveOleObject('Excel.Application');
  if oleexcel=unassigned then.....
Gruß
K-H

API 23. Aug 2018 15:55

AW: Prüfen, ob Excel installiert ist
 
GetActiveOleObject gibt eine Referenz auf die IDispatch-Schnittstelle des aktiven Objekts zurück.
Damit wird nicht überprüft, ob Excel installiert ist.

Und CreateOleObject('Excel.Application') erzeugt eine Excel Instanz, welche im Hintergrund weiterläuft, falls diese nicht beendet wird.

KodeZwerg 23. Aug 2018 16:04

AW: Prüfen, ob Excel installiert ist
 
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:

Zitat von p80286 (Beitrag 1411425)
Zitat:

Zitat von Luckie (Beitrag 1411363)

Warum bei einer einfachen True/False Abfrage eine Exception missbrauchen? Exceptions sind eigentlich dazu gedacht Fehler zu behandeln, die man nicht selbst beeinflussen kann. Netzwerkstecker wird gezogen, Festplatte voll, Diskette wird vom Benutzer ausgeworfen. Und die kein sinnvolles weiter Ausführen des Codes an der Stelle erlauben. Und du verschachtelst sogar noch zwei Exceptions.

Und was wäre die Alternative?
Delphi-Quellcode:
olevExcel := GetActiveOleObject('Excel.Application');
  if oleexcel=unassigned then.....
Gruß
K-H

Anhang 49817
Testet Ihr eigentlich das?
Eine Test-Möglichkeit wäre das 'Excel.Application' mit Quatsch zu ersetzen und schauen was passiert.
Ob nun als exception wie beim Chemiker oder Fehler wie das obige,
man will doch eigentlich genau so etwas verhindern?

Zitat:

Zitat von p80286 (Beitrag 1411425)
Und was wäre die Alternative?

Post #2 und #4

KodeZwerg 23. Aug 2018 16:15

AW: Prüfen, ob Excel installiert ist
 
Zitat:

Zitat von API (Beitrag 1411426)
Und CreateOleObject('Excel.Application') erzeugt eine Excel Instanz, welche im Hintergrund weiterläuft, falls diese nicht beendet wird.

Soweit ich weiß beenden sich solche Objekte von alleine oder wenn man, was auch immer vor " := CreateOleObject()" steht einen anderen Wert zuweist, in beiden Fällen sollte es beendet sein, wann auch immer.

Ist das falsch?

Delphi.Narium 23. Aug 2018 16:21

AW: Prüfen, ob Excel installiert ist
 
Delphi-Quellcode:
uses
  ActiveX;

function IsInstalled(AValue : String) : Boolean;
var
  ClassID: TCLSID;
begin
  Result := CLSIDFromProgID(PWideChar(WideString(AVAlue)), ClassID) = S_OK;
end;

function IsExcelInstalled : Boolean;
var
  ClassID: TCLSID;
begin
  Result := CLSIDFromProgID(PWideChar(WideString('Excel.Application')), ClassID) = S_OK;
end;
// oder:
function IsExcelInstalled : Boolean;
begin
  Result := IsInstalled('Excel.Application');
end;

procedure TForm1.WelcheProzedurAuchImmer(Sender: TObject);
begin
  // Prüfen, ob Excel installiert ist:
  if IsExcelInstalled then ShowMessage('ja') else ShowMessage('nein');
  // Prüfen, ob die als Parameter übergebene Software installiert ist:
  if IsInstalled('Excel.Application') then ShowMessage('ja') else ShowMessage('nein');
  if IsInstalled('Word.Application') then ShowMessage('ja') else ShowMessage('nein');
end;

Delphi.Narium 23. Aug 2018 16:25

AW: Prüfen, ob Excel installiert ist
 
Zitat:

Zitat von KodeZwerg (Beitrag 1411428)
Zitat:

Zitat von API (Beitrag 1411426)
Und CreateOleObject('Excel.Application') erzeugt eine Excel Instanz, welche im Hintergrund weiterläuft, falls diese nicht beendet wird.

Soweit ich weiß beenden sich solche Objekte von alleine oder wenn man, was auch immer vor " := CreateOleObject()" steht einen anderen Wert zuweist, in beiden Fällen sollte es beendet sein, wann auch immer.

Ist das falsch?

Dann erstell' doch mal in 'nem Programm Excel und beende Dein Programm, ohne Excel "aufzuräumen." Was bleibt im Taskmanager übrig?

Wenn Excel vorher schon lief?
Wenn Excel vorher noch nicht lief?
Wenn Du vorm Programmende der "Excelvariabel" was anderes zuweist?

KodeZwerg 23. Aug 2018 16:47

AW: Prüfen, ob Excel installiert ist
 
Gesagt, getan, verstanden.:oops:

p80286 23. Aug 2018 21:24

AW: Prüfen, ob Excel installiert ist
 
Zitat:

Zitat von KodeZwerg (Beitrag 1411427)
Zitat:

Zitat von p80286 (Beitrag 1411425)
Zitat:

Zitat von Luckie (Beitrag 1411363)

Warum bei einer einfachen True/False Abfrage eine Exception missbrauchen? Exceptions sind eigentlich dazu gedacht Fehler zu behandeln, die man nicht selbst beeinflussen kann. Netzwerkstecker wird gezogen, Festplatte voll, Diskette wird vom Benutzer ausgeworfen. Und die kein sinnvolles weiter Ausführen des Codes an der Stelle erlauben. Und du verschachtelst sogar noch zwei Exceptions.

Und was wäre die Alternative?
Delphi-Quellcode:
olevExcel := GetActiveOleObject('Excel.Application');
  if oleexcel=unassigned then.....
Gruß
K-H

Anhang 49817
Testet Ihr eigentlich das?
Eine Test-Möglichkeit wäre das 'Excel.Application' mit Quatsch zu ersetzen und schauen was passiert.
Ob nun als exception wie beim Chemiker oder Fehler wie das obige,
man will doch eigentlich genau so etwas verhindern?

Zitat:

Zitat von p80286 (Beitrag 1411425)
Und was wäre die Alternative?

Post #2 und #4

Das wäre ein anderer Weg, aber es geht darum, nicht mit Exceptions zu arbeiten.

Gruß
K-H

Chemiker 23. Aug 2018 22:57

AW: Prüfen, ob Excel installiert ist
 
Hallo zusammen,

@ Luckie: Also, in meinen Programmen machte es absolut keinen Sinn, ohne Excel weiterzuarbeiten. Aus diesem Grund kann man eine Exception verwenden.

@KodeZwerg: Mit Deinem Code (der veraltet ist) baust Du CreateOleObject/GetActiveOleObject eigentlich nur nach.


Bis bald Chemiker

KodeZwerg 24. Aug 2018 18:29

AW: Prüfen, ob Excel installiert ist
 
Zitat:

Zitat von Chemiker (Beitrag 1411483)
@KodeZwerg: Mit Deinem Code (der veraltet ist) baust Du CreateOleObject/GetActiveOleObject eigentlich nur nach.

Eigentlich ruft mein Code die Registry HKEY_LOCAL_MACHINE\SOFTWARE\Classes\CLSID ab soweit ich mich erinnern kann und der OLE Created/Getted nichts.

Ich muss mal debuggen um das nachzuvollziehen was Du da schreibst.

Veraltet? Wie lautet bitte NextGen Befehl der meinen Ersetzt? (CLSIDFromProgID)

MHaitz 27. Aug 2018 14:12

AW: Prüfen, ob Excel installiert ist
 
Vielen Dank schon mal für die vielen Vorschläge.
ich hab mich mal für die Version:
'Result := CLSIDFromProgID(PWideChar(WideString('Excel.Applic ation')), ClassID) = S_OK;'
entschieden.
Noch eine weitere Frage.
Auf neuen Rechnern mit Windows 10 ist meist eine vorinstallierte, aber nicht voll funktionsfähige Excel Version vorhanden, welche wohl zum Kauf einer Volllizenz animieren soll.
In beiden Fällen liefert obige Funktion True.

Gibt es eine Möglichkeit, die 'vorläufige' Version von einer Vollversion vom Programmcode aus zu unterscheiden?

Gruß
MHaitz

KodeZwerg 27. Aug 2018 14:24

AW: Prüfen, ob Excel installiert ist
 
Ich habe leider keine Demo Version davon, aber mein erster Gedanke wäre mich durch die Registry zu wühlen.

Hier siehst Du einen Ansatz dazu.

edit
Ps:
Um nach einer gezielten Registry zu fahnden, hier erfährst Du welche Versionsnummer Du in Registry abfragen musst.

Delphi.Narium 27. Aug 2018 14:29

AW: Prüfen, ob Excel installiert ist
 
In der Registry nachschauen.

In der Gegend von HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Office\11.0\ Common\ProductVersion solltest Du fündig werden.

11.0 kann auch was anderes sein, jenachdem, welches Office installiert ist.

Dann liefert excel version delphi source bei meiner Suchmaschine u. a. dieses: https://stackoverflow.com/questions/...xcel-in-delphi


Alle Zeitangaben in WEZ +1. Es ist jetzt 19:14 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