Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Frage zum Import/Export von Excel Dateien (https://www.delphipraxis.net/77886-frage-zum-import-export-von-excel-dateien.html)

Hallo_Thomas 26. Sep 2006 12:26

Datenbank: sonstiges • Zugriff über: sonstiges

Frage zum Import/Export von Excel Dateien
 
Liste der Anhänge anzeigen (Anzahl: 2)
Hallo, ich hab zu den folgenden Code mal zwei Fragen:

1.In den uses wird ExcelXP verwendet, ist die Form auch lauffähig ohne Excel, bzw. wie kann ich abfragen ob Excel vorhanden ist?

2.Wie Frage ich die verwendeten Zeilen ab? Habs mit ws.Rows.Count probiert, doch da erhalte ich immer nur 65536 als Wert.

Danke für eure Hilfe!

Delphi-Quellcode:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, JvComponentBase, JvDBGridExport,ExcelXP, OleServer;

type
  TForm1 = class(TForm)
    Button1: TButton;
    OpenDialog1: TOpenDialog;
    Button2: TButton;
    SaveDialog1: TSaveDialog;
    procedure Button2Click(Sender: TObject);
    procedure Button1Click(Sender: TObject);
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;

var
  Form1: TForm1;
  s:string;
  excel: TExcelApplication;
  wb: _WorkBook;
  ws: _WorkSheet;
  lcid: INTEGER;
implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
begin
  lcid := GetUserDefaultLCID;
  excel := TExcelApplication.Create(Form1);
  excel.Connect;
  opendialog1.Filter:= 'Exceldateien (*.xls)|*.XLS';
  IF not opendialog1.Execute THEN exit;
   s:= opendialog1.FileName;
  // Exceldatei laden (test.xls)
  wb := excel.Workbooks.Open(s, emptyParam, emptyParam, emptyParam, emptyParam,
  emptyParam, emptyParam, emptyParam, emptyParam, emptyParam, emptyParam,
  emptyParam, emptyParam,emptyParam, emptyParam,lcid);

  // erstes Worksheet auswählen
  ws := wb.Sheets[1] as _WorkSheet;
  // Feld A1 ausgeben
  ShowMessage(ws.Cells.Item[2,1].TEXT);  //Zeile:Spalte
  // Hier in dein Grid übergeben
//...
  wb.Close(FALSE, emptyParam, emptyParam, lcid);
  excel.Quit;

end;

procedure TForm1.Button2Click(Sender: TObject);
begin
  lcid := GetUserDefaultLCID;
  excel := TExcelApplication.Create(Form1);
  excel.Connect;
  Savedialog1.Filter:= 'Exceldateien (*.xls)|*.XLS';
  IF not Savedialog1.Execute THEN exit;
   s:= savedialog1.FileName;
  // Exceldatei laden (test.xls)
  wb := excel.Workbooks.Add(emptyParam,lcid);
  ws := wb.Sheets[1] as _WorkSheet;


  ws.Cells.Item[1,1]:='Hallo';
  ws.SaveAs(s, emptyParam, emptyParam, emptyParam, emptyParam, emptyParam, emptyParam, emptyParam, emptyParam, emptyParam);

  wb.Close(FALSE, emptyParam, emptyParam, lcid);
  excel.Quit;
end;

end.

mkinzler 26. Sep 2006 12:29

Re: Frage zum Import/Export von Excel Dateien
 
Zitat:

1.In den uses wird ExcelXP verwendet, ist die Form auch lauffähig ohne Excel,
Nein, da es nur ein vorhandes Excel per COM fernsteuert.
Zitat:

bzw. wie kann ich abfragen ob Excel vorhanden ist?
Wenn die Verbindung nicht funktioniert.

Hallo_Thomas 26. Sep 2006 12:51

Re: Frage zum Import/Export von Excel Dateien
 
Wie kann ich es abfragen damit ich nenn True oder False Wert bekomme?

Bernhard Geyer 26. Sep 2006 13:07

Re: Frage zum Import/Export von Excel Dateien
 
Zitat:

Zitat von Hallo_Thomas
Wie kann ich es abfragen damit ich nenn True oder False Wert bekomme?

AFAIK gibt es eine Exeption bei den Zeilen:

Delphi-Quellcode:
excel := TExcelApplication.Create(Form1);
excel.Connect;
oder du prüfst ob du Excel verwenden kannst mittels:

Delphi-Quellcode:
try
  CreateOleObject('Excel.Application');
  result := True;
except
  result := False;


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