![]() |
Excel - Export ohne Excel - Problem beim erzeugen
Hallo Delphianer,
habe folgendes Problem: mit diesem Code lässt sich mit einer zusätzlichen Unit eine Excel-Datei erzeugen ohne eine lauffähige Installation:
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var XLSFile : TXLSExport; x, y : Integer; begin if savedialog1.Execute then begin if fileexists(savedialog1.filename) then DeleteFile(savedialog1.filename); XLSFile := TXLSExport.Create(savedialog1.filename); try y := 0; table1.DisableControls; table1.First; while not table1.eof do begin if y = 0 then begin // Kopfzeilen for x := 0 to table1.FieldCount-1 do XLSFile.Write( x, y, table1.Fields[x].displayname); end else for x := 0 to table1.FieldCount-1 do begin case table1.Fields[x].DataType of ftDate, ftTime, ftDateTime, ftBoolean, ftString, ftFixedChar : XLSFile.Write( x, y, table1.Fields[x].asstring); ftAutoInc, ftSmallint, ftInteger, ftWord : XLSFile.Write( x, y, table1.Fields[x].asInteger); ftFloat, ftCurrency : XLSFile.Write( x, y, table1.Fields[x].asFloat); end; end; inc(y); table1.next; end; XLSFile.free; finally end; table1.EnableControls; end; end; Diese habe ich abgeändert, da ich im Prinzip das gleiche aber aus einer Stringgrid exportieren möchte:
Delphi-Quellcode:
Nun funktioniert das aber nicht richtig, die Datei wird zwar erzeugt, aber nicht korrekt. Das heißt Excel XP kann sie öffnen, sagt aber, dass die Datei repariert werden musste. Nach dem Öffnen ist sie dann auch so wie sie sein soll.
procedure TForm1.Button1Click(Sender: TObject);
var XLSFile : TXLSExport; x, y : Integer; Spalten, Zeilen: String; begin if savedialog1.Execute then begin if fileexists(savedialog1.filename) then DeleteFile(savedialog1.filename); XLSFile := TXLSExport.Create(savedialog1.filename); try y := 0; repeat Spalten := StringGrid2.Cells[x,y]; XLSFile.Write(x,y,Spalten); x := 0; repeat Zeilen := StringGrid2.Cells[x,y]; XLSFile.write(x,y, Zeilen); x := x + 1; until x = StringGrid2.ColCount; y := y + 1; until y = StringGrid2.RowCount; finally XLSFile.free; end; end; end; Dennoch ist dieser Zustand logischerweise unbefriedigend. Meine Vermutung ist, dass es daran liegt:
Delphi-Quellcode:
Obwohl ich dachte, dass ein String nicht extra umgewandelt werden muss, ist wohl doch so, anders kann ich es mir nicht erklären.
XLSFilewrite(x,y, .....asstring);
Meine Frage ist nun, wie lautet die korrekte Syntax für meinen modifizierten Programmteil? Habe alles mögliche versucht, Delphi bietet in der IDE sogar was an, meckert dann aber beim Übersetzen.
Delphi-Quellcode:
Danke im Voraus
XLSFilewrite(x,y,asstring(Zeilen);
|
Re: Excel - Export ohne Excel - Problem beim erzeugen
Kann mir keiner helfen --> ich weiß, es ist viel Text. :cry:
Es geht im Grunde nur um die korrekte Syntax von
Delphi-Quellcode:
.asstring...
|
Re: Excel - Export ohne Excel - Problem beim erzeugen
Die Deklaration von XLSFileWrite wäre ganz sinnvoll.
Wie ist das denn deklariert? Als 'Procedure XLSFileWrite (X,y : Integer; Const s : String)' oder wie? Und, was ist das für eine XLS-Unit? Klingt interessant. |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Hallo alzaimar,
ich habe nichts ausgelassen. Da ist der komplette Auschnitt aus dem Programm. Ich hatte wiegesagt vermutet, dass sich die Deklaration aus dem .asstring ergeben soll.... Hier die Unit:
Delphi-Quellcode:
Vielleicht kannst du dir nun einen Reim drauf machen ?!?!
unit u_ExportEXCEL;
interface uses classes; type TXLSExport = class(TObject) private fs : TFilestream; public constructor Create(filename : string); destructor Destroy; override; procedure Write(const Col, Row: Word; const Value: Integer); overload; procedure Write(const Col, Row: Word; const Value: Double); overload; procedure Write(const Col, Row: Word; const Value: string); overload; end; implementation const CXlsBof : array[0..5] of Word = ($809, 8, 00, $10, 1, 0); CXlsEof : array[0..1] of Word = ($0A, 00); CXlsLabel : array[0..5] of Word = ($204, 0, 0, 0, 0, 0); CXlsNumber : array[0..4] of Word = ($203, 14, 0, 0, 0); CXlsRk : array[0..4] of Word = ($27E, 10, 0, 0, 0); constructor TXLSExport.Create(filename : string); begin inherited Create; fs := TFileStream.Create(filename,fmCreate); fs.WriteBuffer(CXlsBof, SizeOf(CXlsBof)); end; destructor TXLSExport.Destroy; begin fs.WriteBuffer(CXlsEof, SizeOf(CXlsEof)); inherited Destroy; end; procedure TXLSExport.Write(const Col, Row: Word; const Value: Integer); var V: Integer; begin CXlsRk[2] := Row; CXlsRk[3] := Col; fs.WriteBuffer(CXlsRk, SizeOf(CXlsRk)); V := (Value shl 2) or 2; fs.WriteBuffer(V, 4); end; procedure TXLSExport.Write(const Col, Row: Word; const Value: Double); begin CXlsNumber[2] := Row; CXlsNumber[3] := Col; fs.WriteBuffer(CXlsNumber, SizeOf(CXlsNumber)); fs.WriteBuffer(Value, 8); end; procedure TXLSExport.Write(const Col, Row: Word; const Value: string); var L: Word; begin L := Length(Value); CXlsLabel[1] := 8 + L; CXlsLabel[2] := Row; CXlsLabel[3] := Col; CXlsLabel[5] := L; fs.WriteBuffer(CXlsLabel, SizeOf(CXlsLabel)); fs.WriteBuffer(Pointer(Value)^, L); end; end. |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Hach, hätt nur hinshauen müssen, kukstu:
Delphi-Quellcode:
Das sollte reichen....
procedure TForm1.Button1Click(Sender: TObject);
var XLSFile : TXLSExport; x, y : Integer; Spalten, Zeilen: String; begin if savedialog1.Execute then begin if fileexists(savedialog1.filename) then DeleteFile(savedialog1.filename); XLSFile := TXLSExport.Create(savedialog1.filename); try y := 0; repeat Spalten := StringGrid2.Cells[x,y]; <--- wieso das denn? XLSFile.Write(x,y,Spalten); <-- welchen Wert hat x beim 1.Durchlauf? x := 0; repeat Zeilen := StringGrid2.Cells[x,y]; XLSFile.write(x,y, Zeilen); x := x + 1; until x = StringGrid2.ColCount; y := y + 1; until y = StringGrid2.RowCount; finally XLSFile.free; end; end; end; |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Hallo ihr zwei,
niedliche unit - keine Probleme.
Delphi-Quellcode:
Grüße vom marabu
procedure TDemoForm.SaveButtonClick(Sender: TObject);
var xf: TXLSExport; iCol, iRow: integer; begin if not SaveDialog.Execute then Exit; if FileExists(Savedialog.Filename) then DeleteFile(SaveDialog.Filename); xf := TXLSExport.Create(savedialog.filename); for iRow := 0 to StringGrid.RowCount - 1 do for iCol := 0 to StringGrid.ColCount - 1 do if iRow = 0 then // Ausgabe Spaltenköpfe als string xf.Write(iCol, iRow, StringGrid.Cells[iCol, iRow]) else // der Rest sind integer Werte xf.Write(iCol, iRow, StrToInt(StringGrid.Cells[iCol, iRow])); xf.Free; end; |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Vielen Dank marabu,
klappt wunderbar. Musste nur strtoint aus deiner Routine rausnehmen, da ich auch nicht-Zahlenwerte Quer durch die Tabelle hab. Macht aber nix, da das ganze nur einen Report mehrere Messdateien darstellt, welcher nur zum Gugge is, und nicht zum Rechnen. Hallo alzaimar
Delphi-Quellcode:
Das mit den extra Variablen war nur zu Testzwecken, ohne tieferen Sinn.
repeat
Spalten := StringGrid2.Cells[x,y]; <--- wieso das denn? XLSFile.Write(x,y,Spalten); <-- welchen Wert hat x beim 1.Durchlauf? x := 0; repeat Vielen Dank nochmal Padavan |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Hallo!
was müsste man an der Unit groß ändern um Unicode damit zu Exportieren? hab mal experimentell statt String als Parameter WideString genommen. Nur hab ich dummerweiße dann so doofe Kästchen statt buchstaben... irgendwie klappt das nich ganz. Daniel |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Zitat:
Z.B. bei ![]() |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Hmmm eigentl. Hast ja recht. Bloß bin ich davon ausgegangen das ms. Excel unicode unterstützt.
oder nicht? |
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:14 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz