Heiner KückerJava to Excel conversion with Sylk format |
|
Home Java-Seite Bit Packed Array ASM Improved heterogene Map, HMap Constraint Code Generator JSP WorkFlow PageFlow FlowControl Page Flow Engine Web Flow Engine Control_and_Command JSP_Spreadsheet Code-Generator für Option-Either-Stil in Java verbesserter Comparator Fluent-Interface Code-Generator auf Basis einer Grammatik Visitor mit Multidispatch for-Schleife mit yield-return Kognitions-Maschine semantisches Netz Domain Parser Codegenerator_für hierarchische Datenstrukturen Expression_Engine Formula_Parser Thread Preprocessor State Transition Engine AspectJ Java_Explorer DBF_Library Kalender_Applet SetGetGen BeanSetGet CheckPackage LineNumbers GradDms Excel-Export StringTokenizer JspDoc JspCheck JSP-Schulung Java Server Pages Struts Ascii-Tabellen- Layouter Ascii-Baum- Layouter Ascii-Art-Fluss- Diagramm- Parser AsciiArt AssignmentMatrix Layouter StringSerial Silbentrennung JDBC_Schlüssel- Generierung bidirektional/ unidirektional gelinkte Liste Java_Sitemap Generator XmlBuilder RangeMap StringFormatter VersionSafe XCopy JTextField CommandLine- ParamReader Bitmap-Grafik MultiMarkable- Buffered- InputStream JavaCache JdomUtil CollectionUtil XML Really Pull Parser Log-Filter Remote-Protokoll Sudoku-Generator Delegation statt Mehrfachvererbung Disjunct Interval Set WebCam_Demo Weiterentwicklung_Java Alaska-XBase++-Seite Projekte Philosophien Techniken Konzepte Sudoku Kontakt / Impressum Links SiteMap Letzte Aktualisierung: 09.06.2003 |
Java to Excel Export Konverter
Klassen zum Daten-Export zu Microsoft-Excel über das SYLK-Format (Symbolik Link), Excel-Export. So sieht es aus (wenn Excel installiert ist) SylkCell.java Die Klasse SylkCell dient zur Speicherung jeweils einer Zelle des Excel-Sheets. Ein Zelle kann folgende Eigenschaften haben: -Text als String -Wert als numerischer String -Formel als encodeter String -Ausrichtung Standard, links, rechts oder mittig numerisch codiert Sylk.java Ein Objekt der Klasse Sylk speichert die einzelnen Zellen (SylkCell) als zweidimensionales Array. Im Konstruktor wird die Größe des auszugebenden Sheets ( Zeilen x Spalten ) festgelegt. Sylk stellt Methoden zum Setzen der einzelnen Zellen, zum Festlegen der Spaltenbreiten und zur Ausgabe in einen OutputStream oder als ByteArray zur Verfügung. Eine Besonderheit sind die Methoden zur Erzeugung einer Summenformel (setCellSummeFormel) und einer bedingten Summenformel(setCellSummeWennFormel). Sylk (Excel) unterstützt noch zahlreiche weitere Formeln, aber nur diese beiden habe ich benötigt. Die Ausgabe-Methode in einen OutputStream ermöglicht die Erzeugung einer Datei oder das Senden in eine HTTP-Response im Servlet. Über die Methode setbClEraseMode(boolean) kann der Schalter bClEraseMode gesetzt werden. Dieser Schalter sorgt dafür, daß beim Erzeugen der Ausgabe nicht mehr benötigte Daten (Zellen) gelöscht werden. Standardeinstellung ist Löschen == ja. Dadurch wird der Speicher für die Zellen sofort nach dem Generieren freigegeben. Zur mehrfachen Ausgabe, z.B. beim Debugging kann das Löschen ausgeschaltet werden. SylkServlet.java Die SYLK-Daten werden direkt in die http-Response gesendet. Dadurch ist keine temporäre Datei nötig. Dem Browser wird durch den MIME-Typ mitgeteilt, das es sich um Excel-Daten handelt. res.setContentType( "application/vnd.ms-excel" ) ; // MIME-Typ festlegen Bei installiertem Excel wird dieses als Plug-In im Browser oder als externes Programm geöffnet (abhängig von Browser und Installation Excel). Falls Excel nicht installiert ist, erhaelt der Anwender eine Dialog-Box Öffnen/Speichern. Zum Kompilieren ist die Datei servlet.jar aus dem Sun J2EE SDK nötig. SylkToFile.java Testprogramm zum Erzeugen einer SYLK-Datei. Erzeugt die Datei TestSylkToFile.slk. Problem Formeln Leider werden in unterschiedlichen Excel-Versionen die Relativ-Positionierungen in den Formeln unterschiedlich codiert. Excel 97 verwendet runde Klammern dagegen Excel 2000 eckige Klammern. Falls die Methoden für die Formeln verwenden werden sollen (habe ich auskommentiert) müssen diese entsprechend anpasst werden, oder sogar zwei Versionen mit entsprechender Abfrage an den User (Excel Version 97 oder 2000) programmiert werden. Beispiele fü die unterschiedlichen Codierungen enthalten die Dateien TestSylkToFile.slk-Win2000_XP und TestSylkToFile.slk-Win_NT_98. Informationen Basis für diese Library war das Buch Dateiformate – Die Referenz von Günter Born. Galileo Computing, Buch - Dateiformate – Die Referenz Debugging Um die konkrete Codierung für eine bestimmte Formel oder Formatierung herauszubekommen, kann man ein entsprechendes Excel-Sheet anlegen und mit Speichern unter Dateityp SYLK (symbolische Verbindung) (*.slk) eine entsprechende SYLK-Datei erzeugen. Diese kann man mit einem Texteditor ansehen oder bearbeiten. Download der Quelldateien Java2Excel_Sylk.zip
Achtung: Erweiterungen und Fixes stelle ich ohne Historie
und ohne Ankündigung hier bereit. Lizenzbedingungen:
Die Programme, Quelltexte und Dokumentationen können ohne
irgendwelche Bedingungen kostenlos verwendet werden. |