AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Per Delphi-OLE PDF über mehrere Excel-Arbeitsblättern erstellen

Per Delphi-OLE PDF über mehrere Excel-Arbeitsblättern erstellen

Ein Thema von norwegen60 · begonnen am 19. Mär 2015 · letzter Beitrag vom 24. Mär 2015
Antwort Antwort
norwegen60

Registriert seit: 23. Dez 2007
Ort: Schwarzwald
504 Beiträge
 
Delphi 12 Athens
 
#1

Per Delphi-OLE PDF über mehrere Excel-Arbeitsblättern erstellen

  Alt 19. Mär 2015, 10:42
Hallo zusammen,

ich speichere per
Delphi-Quellcode:
var
     ovExcelApp, ovDoc, ovSheet: OLEVariant;
begin
  ovExcelApp := CreateOLEObject('Excel.Application');
  ovExcelApp.Visible := False;
  ovDoc := ovExcelApp.Workbooks.Open(sDocument, EmptyParam, true, EmptyParam, sPW, sPW, EmptyParam, EmptyParam, EmptyParam, EmptyParam);
  ovDoc.Sheets[2].Select;
  ovSheet := Doc.ActiveSheet;
  ovSheet.ExportAsFixedFormat(0, sVersDoc, EmptyParam,
                               EmptyParam,
                               EmptyParam,
                               EmptyParam,
                               EmptyParam,
                               EmptyParam, //set to True to open Acrobat
                               EmptyParam
                               );
ein Excel-Dokument als PDF ab.

Wie kann ich in dem Excel-Dokument alle Arbeistblätter (und nicht nur wie oben Arbeitsblatt 2) selektieren, so dass alle als PDF gespeichert werden.

Ich habe alle Sicherheitsabfragen und den Schließvorgang aus obigem Code mal weggelassen.

Danke
Gerd
  Mit Zitat antworten Zitat
puderle
(Gast)

n/a Beiträge
 
#2

AW: Per Delphi-OLE PDF über mehrere Excel-Arbeitsblättern erstellen

  Alt 20. Mär 2015, 08:46
Nicht nur das Sheet. Du kannst auch das ganze Workbook (Arbeitsmappe) darin sind die Sheets enthalten exportieren

https://msdn.microsoft.com/de-de/lib...v=vs.100).aspx

Du kannst auch einzelne Seiten exportieren und sie später mit pdftk zusammenfügen.


Der beste Weg ist aber wahrscheinlich einfach die Sheets zu selektieren und die Auswahl dann exportieren mit
Code:
selection.exportasfixedformat()
  Mit Zitat antworten Zitat
norwegen60

Registriert seit: 23. Dez 2007
Ort: Schwarzwald
504 Beiträge
 
Delphi 12 Athens
 
#3

AW: Per Delphi-OLE PDF über mehrere Excel-Arbeitsblättern erstellen

  Alt 24. Mär 2015, 20:11
Hallo,

genau das sind eigentlich die zwei Wege, die ich probiert habe.
Als Workbook
Delphi-Quellcode:
var
      ovExcelApp, ovDoc: OLEVariant;
begin
   ovExcelApp := CreateOLEObject('Excel.Application');
   ovExcelApp.Visible := False;
   ovDoc := ovExcelApp.Workbooks.Open(sDocument, EmptyParam, true, EmptyParam, sPW, sPW, EmptyParam, EmptyParam, EmptyParam, EmptyParam);
   ovDoc.Workbooks.ExportAsFixedFormat(0, sVersDoc, EmptyParam,
                                EmptyParam,
                                EmptyParam,
                                EmptyParam,
                                EmptyParam,
                                EmptyParam, //set to True to open Acrobat
                                EmptyParam
                                );
kommt die Fehlermeldung
Zitat:
EOleEerror. Die Methode 'Doc' wird vom Automatisierungsobjekt nicht unterstützt
und bei meinem anderen Code suche ich ja gerade die Möglichkeit, wie ich die einzelnen Sheets selektieren kann. MitovDoc.Sheets[2].Select; wird eben nur Blatt 2 selektiert und ein Array wird nicht akzeptiert. Oder ich gebe es falsch an.

Noch ein Tip der mir weiter hilft?
Gerd
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 12:01 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