Wie kann ich in Apache POI (Excel Dateien schreiben) Datumszellen in Excel erzeugen

osix

Bekanntes Mitglied
Hallo Leute,

mit dieser Methode möchte ich bliebige Spalten die als ArrayListen vorliegen in eine xlsx-Datei schreiben.
Ich kann beliebig viele ArrayListen übergeben, und das funktioniert auch - vom Prinzip her schon, die Methode unten ist nur ein "Proof of Consept" noch nicht "schön" ausgeführt..

Unten kann ich eine Typen abfrage durchführen, das hab ich nur mal für STRING ausgeführt, das geht natürlich auch für DOUBLE als mit CellType.NUMERIC

Und jetzt meine Frage:

Was mach ich mit DATUMspalten ? Ich bin irritiert, Apache POI kennt komischerweise den CellType.DATE nicht !

Ich möchte aber Datumsspalten schreiben, wie kann ich das schaffen.


Java:
public void writeArrayListToXLSX(File filename,ArrayList... al) throws FileNotFoundException, IOException
    {               
        Row row;
        Cell c = null;
                                
        XSSFWorkbook workbook = new XSSFWorkbook();
        XSSFSheet sheet = workbook.createSheet();
                
        for (int i=0; i<al[1].size(); i++)  // über alle Reihen, also nach unten !
        {           
            row = sheet.createRow(i);  // Die i.te Reihe wird angelegt

            for (int p=0; p<al.length; p++)                       
            {
                 System.out.println("i:"+i+" p: "+p);
                 String klasse=al[p].get(0).getClass().toString();  // stellt fest welcher Art, das Array und somit die ganze Spalte ist

                 if (klasse.contains("String"))   {
                                                        c = row.createCell(p, CellType.STRING);  // Die p.te Zelle in der Reihe wird festgelegt
                                                                                                                
                                                        c.setCellValue((String) al[p].get(i));   // Cast nötig
                                                  
                                                        // c.setCellStyle(style);                // Die p.te Zelle (oben festgelegt) wird mit dem i.ten Element belegt
                                                        System.out.println("i:"+i+" p: "+p+" Zelle c:"+c);
                                                  }   
                
            }   
        }   
        FileOutputStream outFile = new FileOutputStream(filename);
        workbook.write(outFile);               
    }
 

osix

Bekanntes Mitglied
ja danke, daß geht zwar

Java:
 c.setCellValue(new Date(1978,2,2));

weil ich nicht gedacht habe, daß ich nicht unbedingt einen CELLTYPE übergeben muß ( c = row.createCell(p, CellType.STRING); ) Man kann den letzten Parameter auch weglassen.

Dummerweise wird in Excel mit obigem Datum 1978,2,2 eingetragen "2-Mär-3878"


Java:
CellStyle style = workbook.createCellStyle();
                                                        style.setDataFormat(cp.createDataFormat().getFormat("m/d/yy h:mm"));
                                                        c.setCellStyle(style);
                                                                                                               
                                                        c.setCellValue(new Date(1978,2,2));

Warum ???
auch wenn ich in getFormat das umstelle auf yyyy/m/d nützt das nichts
 
K

kneitzel

Gast
ok, ja habs selber rausgefunden

Date will Jahr ab 1970, Monat 0=Januar, letzte Stelle Tag von 1 bis 31
Nein, das ist falsch. @mihe7 hat doch den Link gegeben:
year - the year minus 1900.
month - the month between 0-11.
date - the day of the month between 1-31.

Also Jahr ab 1900 und nicht ab 1970! Das zeigen ja auch Deine Werte, denn 3878 - 1978 = 1900.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Apache POI/ neue Reihe in Excel mit einem Button Allgemeine Java-Themen 2
L JavaFX JavaFX Chart in Apache Poi Excel Datei Allgemeine Java-Themen 2
J Apache POI Excel- Blattschutz aufheben Allgemeine Java-Themen 2
T Geschlossen: Apache POI - Excel einlesen Allgemeine Java-Themen 0
H Excel Datei einlesen mit Apache POI Allgemeine Java-Themen 1
T Mit Apache Poi Daten aus einer Excel Tabelle kopieren und in Word einfügen Allgemeine Java-Themen 1
G Input/Output Apache POI Excel Allgemeine Java-Themen 5
V Apache POI Excel Datum auslesen Allgemeine Java-Themen 6
V Apache POI Excel Sheet auslesen Allgemeine Java-Themen 5
T Apache POI Export EXCEL - [Zahlen-Werte] Allgemeine Java-Themen 1
G mit Apache-Jakarta-POI auch Graphiken aus Excel einlesen? Allgemeine Java-Themen 3
M Apache Proxy Weiterleitung auf Tomcat funktioniert nicht wie gewünscht Allgemeine Java-Themen 1
T Logging mit org.apache.logging.log4j Allgemeine Java-Themen 1
E Ersetzen eines Bildes in der Kopfzeile eines Word-Docx-Dokuments mit Apache POI XWPF Allgemeine Java-Themen 0
H Apache fop -- welche Möglichkeit gibt es um den Fortschritt anzuzeigen (Progressbar) Allgemeine Java-Themen 5
H Apache fop - OutOfMemoryError Allgemeine Java-Themen 10
B Schnittstelle zwischen MySQL und Apache Allgemeine Java-Themen 8
F Fehlermeldung: java.lang.NoClassDefFoundError: org/apache/commons/net/ntp/NTPUDPClient Allgemeine Java-Themen 6
I Apache POI Bild in Word ersetzen Allgemeine Java-Themen 15
O xlsx Datei auslesen mit POI Apache liest keine LEERZELLEN Allgemeine Java-Themen 6
O xlsx Datei auslesen mit POI von Apache wirft seltsamen Fehler. Allgemeine Java-Themen 11
L APACHE POI PIVOT TABELLEN Allgemeine Java-Themen 4
L Apache POI Datenquelle Allgemeine Java-Themen 1
S Apache POI Filtern nach bestimmten Kriterium Allgemeine Java-Themen 1
F Operationen/Methoden einen WebService im Browser mit Apache Axis aufrufen Allgemeine Java-Themen 4
F Input/Output NullPointerException, aber wieso? [Apache POI] Allgemeine Java-Themen 11
F Input/Output NullPointerException with Apache POI Allgemeine Java-Themen 7
E HILFE !! Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/io/FileUtils Allgemeine Java-Themen 4
J Apache POI - No external workbook with name Allgemeine Java-Themen 5
M Suche aktuelle Apache Poi Bibliothek zum Einbinden in mein Programm Allgemeine Java-Themen 2
MiMa Apache Tika: Warnmeldungen und Beispielcode Allgemeine Java-Themen 12
X Performance für Tomcat / Apache optimieren Allgemeine Java-Themen 2
G Ant Probleme bei einer Installation die Apache ant+ivy verwendet Allgemeine Java-Themen 14
FrittenFritze Swing Apache Batik - Zoom an einer bestimmten Stelle Allgemeine Java-Themen 4
K Apache poi: Deprecated getCellType Allgemeine Java-Themen 3
I Apache POI Word Text einfügen Allgemeine Java-Themen 26
K Apache POI Word Tabelle Zellen verbinden Allgemeine Java-Themen 4
K Apache POI Word Tabelle Spaltenbreite festlegen Allgemeine Java-Themen 7
K Apache POI Word bestimmte Textstellen bearbeiten Allgemeine Java-Themen 1
R Apache POI XSSF Allgemeine Java-Themen 2
E Apache POI Powerpoint Verlinkungen ändern Allgemeine Java-Themen 4
T xls-Datei per Apache Commons CsvParser einlesen UTF-8 Zeichen russische Zeichen Allgemeine Java-Themen 2
zer0zer0 Best Practice apache common cli - optionen für hilfe ausblenden Allgemeine Java-Themen 5
S Eclipse Apache Camel FTP: Fehlerbehandlung, wie? Allgemeine Java-Themen 2
GianaSisters Apache POI - Hyperlink erstellen Allgemeine Java-Themen 0
reibi Apache PDFBox Allgemeine Java-Themen 0
C Was bekomme ich eine Nullpointerexception? (Apache POI) Allgemeine Java-Themen 3
S OOP Apache Commons Math - Verwendung von Genetics - Wie werden Daten in Chromosomen gespeichert? Allgemeine Java-Themen 4
H Apache POI HSSF - Farbe/Rahmen etc. ohne Style-Vorlage? Allgemeine Java-Themen 4
E Apache POI-Datei lesen und umschreiben Allgemeine Java-Themen 8
L Apache CLI: Args[] übergeben Allgemeine Java-Themen 3
P docx mit Apache POI auslesen, verändern und zurückschreiben Allgemeine Java-Themen 2
N Applet Apache Poi Wert einer Formel ausgeben Allgemeine Java-Themen 5
L Apache Common CLI Allgemeine Java-Themen 4
J Webstart (auf Apache) jnlp wird nicht geladen Allgemeine Java-Themen 2
S HTTP Apache HTTPClient Problem Allgemeine Java-Themen 4
R org.apache.http kompletter Internetausfall Allgemeine Java-Themen 7
J xlsx Dateien lesen OHNE apache POI Allgemeine Java-Themen 6
V Für was benötigt man Apache Common Allgemeine Java-Themen 3
B Problem mit RegEs und org.apache.regexp.RE Allgemeine Java-Themen 5
Landei Erfahrungen mit JavaConfig oder Apache Commons Config? Allgemeine Java-Themen 3
J Apache FTPClient upload Allgemeine Java-Themen 3
A Apache License, Version 2.0 Allgemeine Java-Themen 7
S Bzip2 apache commons-compress Allgemeine Java-Themen 3
Chris81T Apache FOP 0.20-5 mit JNI von C++ Code aufrufen Allgemeine Java-Themen 8
C Apache POI(HSSF) Conditional Formatting Allgemeine Java-Themen 3
G Apache soll mit SVN zusammenarbeiten Allgemeine Java-Themen 3
E Apache Commons - PropertyConfiguration - Autosave Allgemeine Java-Themen 2
G Servlet über apache Tomcat ansprechen Allgemeine Java-Themen 6
alexpetri DirectoryWalker apache.commons Allgemeine Java-Themen 3
S Apache Commons Net geht nicht Allgemeine Java-Themen 5
T Apache Lucene Allgemeine Java-Themen 2
Q Ant und org.apache.log4j.xml.DOMConfigurator Problem Allgemeine Java-Themen 2
M Java Webserver - Tomcat alleine oder zusammen mit Apache? Allgemeine Java-Themen 3
OnDemand Excel lesen wie CSV Allgemeine Java-Themen 7
M Excel Datei Erstellen Allgemeine Java-Themen 2
I HTML / XHTML Seite nach Excel exportieren. Suche Lib Allgemeine Java-Themen 12
D ODS.Datei öffnet leider in Excel Allgemeine Java-Themen 3
G Excel File öffnen, in Zelle schreiben, abspeichern Allgemeine Java-Themen 6
G Excel Datum richtig auf der Konsole ausgeben Allgemeine Java-Themen 1
G Excel Tabelle lesen und in neue Excel Tabelle einfügen Allgemeine Java-Themen 11
Trèfle Excel-Datei nicht speicherbar, da von Java zum Bearbeiten gesperrt. Allgemeine Java-Themen 3
L Excel Datei löscht sich selbst im Programm - Java Allgemeine Java-Themen 3
C Aus MEHREREN Excel Tabellen bestimmte Zelle addieren Allgemeine Java-Themen 1
offi Excel mit Inhalten aus DB öffnen ohne zu speichern Allgemeine Java-Themen 8
C Zeilen-"Vektor" aus Excel-Tabelle suchen Allgemeine Java-Themen 0
R EXCEL Range und HSSF POI CellRangeAddress Allgemeine Java-Themen 1
ms_cikar Java Excel bearbeiten spalten werden überschrieben. Allgemeine Java-Themen 4
U Java Excel export Allgemeine Java-Themen 1
M Excel Formel in Java Allgemeine Java-Themen 7
D Mit Hilfe von Java aus Excel-Sheet Zellen in neues Excel Dokument kopieren Allgemeine Java-Themen 3
A In Excel-Datei schreiben, Formeln der Mappe anwenden, Wert lesen Allgemeine Java-Themen 3
T Java Excel Drop Down Formularsteuerelement Allgemeine Java-Themen 0
C Benutzereingabe von EXCEL-Funktionen parsen Allgemeine Java-Themen 4
T Excel - mit jxf sprachabhängige Formeln schreiben Allgemeine Java-Themen 2
J Ausgabe nach Excel Allgemeine Java-Themen 1
Todesbote Zeilen aus Excel in andere Excel Tabelle kopieren Allgemeine Java-Themen 0
Todesbote Excel Zellen umranden Allgemeine Java-Themen 1
Todesbote Excel Blattschutz aufheben und Daten einfügen Allgemeine Java-Themen 3
G Langtexte - Cellformat import in Excel Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben