![]() |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Zitat:
|
Re: Excel - Export ohne Excel - Problem beim erzeugen
Hallo Bernhard Geyer,
Zitat:
Bis bald Chemiker |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Ich komme hier nicht weiter.
Auch nach (oder gerade wegen) zahlreicher Lektüre komme ich nicht darauf, wie ich meinen File-Stream nach Excel auf UTF8 forcen kann. Es bleiben Kästchen-Steuerzeichen nach jedem Char, während die eigentlichen Unicodezeichen (kyrillisch in meinem Fall) nicht übersetzt werden. Sprich, da werden Ansi-Strings reingebügelt. Was ich an der Sache nicht verstehe ist, dass die Strings die ich übergebe (Momentan z.B. an TXLSExport.Write) ja Unicodestrings sein sollen. Wie gesagt funktioniert der Export in Textfiles ohne Probleme. Edit: Bin nun soweit, dass ich denke, dass das Ganze relativ einfach mit den definierten Records zusammenhängt.
Delphi-Quellcode:
Kann mir vielleicht jemand sagen, wo die Werte herkommen, bzw. wie die sich zusammensetzen?
CXlsBof : array[0..5] of Word = ($809, 8, 00, $10, 0, 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); Chemiker beschreibt ja in seiner unit zumindest grob, was die Werte darstellen, aber wie und ob ich die ändern kann/darf leider nicht. Hab mich blind-gegoogelt, aber bisher nichts gefunden. |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Hallo alphafligt83,
ich habe die Informationen, die Du für Deine Anpassung benötigtst schon im Link von #19 geschrieben. Es reicht leider nicht die Angaben in dem Record zu ändern und schon läuft alles unter UniCode, da muss leider etwas mehr Arbeit hereingesteckt werden. Bis bald Chemiker |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Zitat:
|
Re: Excel - Export ohne Excel - Problem beim erzeugen
Hmm,
wäre ganz nett auch noch eine entsprechende Unit für den Import zu haben. Viele Grüsse |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Hallo R2009,
das ist mit sehr viel Aufwand verbunden, aber unmöglich ist es nicht. Bisher reichte mir die OLE-Automation, vernünftig programmiert ist sie eigentlich auch relativ schnell. Bis bald Chemiker |
Re: Excel - Export ohne Excel - Problem beim erzeugen
Da sollte man sich langfristig aber auf das neue xml-Excelformat konzentrieren... /// Grüße Martin
PS: Dass Biff-Format ist auch bei kommerziellen Komponenten nicht vollständig umgesetzt. Nachdem ich einen Satz von ca. 2000 Excelblättern einlesen mußte, durfte ich im Quellcode von DevExpress einige mal nachfassen, damit das System nicht mit Speicherfehlern ins Nirwana verschwandt... |
Re: Excel - Export ohne Excel - Problem beim erzeugen
@ alphaflight83:
chemiker hat ja schon auf seinen Link in #19 hingewiesen. Hier noch einige zusätzliche Erläuterungen zum Quelltext von chemiker:
Delphi-Quellcode:
const
XLS_WORKBOOK = $5; // nur Workbook und separate Sheets XLS_WORKSSHEET= $10; // Sheet or dialogue record (s.S.136 Dokument s. oben) XLS_BOF = $809; // BIFF5 bis BIFF8 (s.S.135 Dokument s. oben) XLS_BIFFVER = $600; // BIFF8 (s.S.136 Dokument s. oben) XLS_LABEL = $204; // (s.S.187, 5.63 Dokument s. oben) XLS_EOF = $A0; // (s.S.161, 5.37 Dokument s. oben) XLS_EXCEL_VERSION = 1; type TXLS_BOFRec= packed record // Start des Datenblockes RecCode: Word; // $809 BOF RecLaenge: Word; // Record Länge // Komplett 16/ normal 8 BIFFVersion: Word; // $600 BiffVersions-Nummer 8 Bereich: Word; // $10 = Worksheet ExcelVersion: Word; // muss nicht angegeben werden (z.B. 2719=Excel 2000) ExcelDatum: Word; // muss nicht angegeben werden end;
Delphi-Quellcode:
Setze ich die BIFF-Version auf 8 durch $600, erhalte ich auch diese schmucken
procedure TXLS_DateiClass.XLS_BOFRecDatenFuellen;
begin with FBOF do begin RecCode:= XLS_BOF ; // $809 RecLaenge:= 8; //BIFFVersion:= XLS_BIFFVER; // $600 BIFF8 BIFFVersion:= 1; // kein BIFF8 Bereich:= XLS_WORKSSHEET; // $10 ExcelVersion:= 1; ExcelDatum:= 0; end; end; Kästchen und Sonderzeichen. BIFF8 ist Unicodefähig. Aber in der erzeugten Datei sind die Texte / Daten, die eigentlich in die Zellen geschrieben werden sollen, unvollständig bzw. verschoben. Excel liest (parst) diese Streams und erwartet an einer bestimmten Position auch bestimmte Angaben für die Formatierung usw. Stehen an diesen Stellen aber z.B. Texte für die Zellen, muß das schief gehen. Das Problem ist also, den Buffer des Streams korrekt zu füllen. Insbesondere, was die Zeichenlängen und Zeilenendezeichen betrifft. Gruß Gerald edit: Die Seitenangaben beziehen sich auf das Dokument compdocfileformat.pdf (s. Beitrag #19). |
Re: Excel - Export ohne Excel - Problem beim erzeugen
@Chemiker: Ich nehme alles zurück und behaupte das Gegenteil :oops:
War gestern Nachmittag wohl einfach zu viel für mich. @GHorn: Danke für die Zusatzinfos. Das hilft mir mal ein Stück weiter. Werd mich dann mal wieder meinem Chaos hier zuwenden. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:11 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