AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Excel über OLE Schnittstelle ansprechen klappt nicht
Thema durchsuchen
Ansicht
Themen-Optionen

Excel über OLE Schnittstelle ansprechen klappt nicht

Ein Thema von DelphiManiac · begonnen am 7. Mär 2007 · letzter Beitrag vom 7. Mär 2007
Antwort Antwort
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#1

Excel über OLE Schnittstelle ansprechen klappt nicht

  Alt 7. Mär 2007, 19:11
Hallo,

ich habe folgendes Problem, ich versuche über OLE auf eine Excelinstanz zuzugreifen, die ich selber erstelle,
dies klappt auch bei WinXP, und Office XP, nur bei Excel 97 und 2000 klappt dieser Quelltext nicht:

Delphi-Quellcode:
uses
  ComObj;

procedure TForm1.Button1Click(Sender: TObject);
var
  ExcelApp: OLEVariant;
begin
  // Create an Excel instance
  // Excel Instanz erzeugen
  ExcelApp := CreateOleObject('Excel.Application');
  try
    ExcelApp.Workbooks.Open('C:\test\xyz.xls');
    // you can also modify some settings from PageSetup
    // Man kann auch noch einige Einstellungen von "Seite Einrichten" anpassen
    ExcelApp.ActiveSheet.PageSetup.Orientation := xlLandscape;
    // Print it out
    // Ausdrucken
    ExcelApp.Worksheets.PrintOut;
  finally
    // Close Excel
    // Excel wieder schliessen
    if not VarIsEmpty(ExcelApp) then
    begin
      ExcelApp.Quit;
      ExcelApp := Unassigned;
    end;
  end;
end;


Es passiert einfach gar nichts (bei Excel 97 / 2000)...
Wisst ihr warum?


Danke
Gruß
DelphiManiac
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: Excel über OLE Schnittstelle ansprechen klappt nicht

  Alt 7. Mär 2007, 19:43
Hallo,

hast du das Statement schon identifiziert, bei dem der Code versagt?

Grüße vom marabu
  Mit Zitat antworten Zitat
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#3

Re: Excel über OLE Schnittstelle ansprechen klappt nicht

  Alt 7. Mär 2007, 19:49
Hi marabu,
nein leider nicht, da ich auf meinem Entwicklungsrechner nur XP + Office 2003 habe (wo es läuft).
Aber beim Kunden ( Win 2000 + Office 2000) läuft es leider nicht...
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#4

Re: Excel über OLE Schnittstelle ansprechen klappt nicht

  Alt 7. Mär 2007, 20:19
Dann solltest du ein paar Tests einbauen und einen Trace wegschreiben, damit Klarheit herrscht. Es könnte sein, dass Excel beim Kunden nicht richtig installiert wurde. Eventuell hilft auch ein Export des entsprechenden Registry-Ausschnitts (HKCR\Excel.Application etc.) vom Kunden.

Freundliche Grüße
  Mit Zitat antworten Zitat
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#5

Re: Excel über OLE Schnittstelle ansprechen klappt nicht

  Alt 7. Mär 2007, 20:23
hi, was meinst du denn mit

Zitat:
einen Trace wegschreiben, damit Klarheit herrscht
?
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#6

Re: Excel über OLE Schnittstelle ansprechen klappt nicht

  Alt 7. Mär 2007, 21:05
Ich dachte an eine Textdatei, welche du in deinem Programm erstellst und in der du für jedes Statement einen Eintrag machst, der Auskunft gibt, was ausgeführt wurde und welches Ergebnis produziert wurde. So bist du nicht auf einen Kunden angewiesen, der dir entnervt den Text aus unzähligen ShowMessage-Aufrufen vorlesen muss.
  Mit Zitat antworten Zitat
DelphiManiac

Registriert seit: 5. Dez 2005
742 Beiträge
 
#7

Re: Excel über OLE Schnittstelle ansprechen klappt nicht

  Alt 7. Mär 2007, 21:32
Hi,

ja danke, das ist eine Möglichkeit,
aber was für eine Info bekomme ich denn beim Zugriff auf ein Excelobjekt, wie dieser Aufruf?

ExcelApp.Worksheets.PrintOut;
  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 18:45 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