xlsx Datei auslesen mit POI von Apache wirft seltsamen Fehler.

osix

Bekanntes Mitglied
Hallo Freunde,

Ich möchte mit der Library POI von Apache die angehängte Datei mit Spiel-daten lesen.

Es kommt ein Fehler wegen Feld E2,
java.lang.IllegalStateException: Cannot get a STRING value from a NUMERIC cell
at org.apache.poi.xssf.usermodel.XSSFCell.typeMismatch(XSSFCell.java:1077)
at org.apache.poi.xssf.usermodel.XSSFCell.getRichStringCellValue(XSSFCell.java:395)
at org.apache.poi.xssf.usermodel.XSSFCell.getStringCellValue(XSSFCell.java:347)

Das verstehe ich nicht. Das Feld IST definitiv als TEXT-formatiert, die Datei wurde mit MS-Excel erzeugt.

Kann es sein, daß die POI Routinen fehlerbehaftet sind ?

Was könnte ich dann tun, ich muß xlsx-Dateien einlesen...

Danke für eure Antworten.
 

Anhänge

  • 2020_04_30 Testspender.zip
    7,6 KB · Aufrufe: 4

osix

Bekanntes Mitglied
Wieso ? Wenn ich die mit Libre-Office öffne, recht klicke und "Zellen formatieren" anwähle, dann kommt "Text".
Soll ja auch so sein, weil Postleitzahlen ja mit Null anfangen können. Ich kann doch ein Textfeld mit Zahlen auffüllen, wie kommst du drauf, daß die Zelle definitiv numerisch sei ?
 

mihe7

Top Contributor
Das Einstellen des Formats ändert nicht automatisch den Typ.

Probiers einfach aus:

E2 anwählen, in Formelleiste steht 10557, Format -> Zahlformat -> Allgemein, in Formelleiste steht immer noch 10557. Folglich war es ein numerischer Wert.

Um den Unterschied zu sehen, wandelst Du mal E3 zu Text um. Dazu Wert von 20148 zu 0148 ändern. Sofort wird der Text (der es nach der Bearbeitung nun ist, weil das Zellformat Text war) linksbündig angezeigt. In der Formelleiste steht immer noch 0148. Wenn Du jetzt Format -> allgemeine Zahl anwählst, steht in der Formelleiste '0148, also mit Hochkomma.

Nachtrag: Du kannst das auch anders prüfen. Dazu gibst Du in I2 die Formel =ISTTEXT(E2) ein und kopierst die über alle Zeilen runter. Da wird immer FALSCH erscheinen. Wenn Du jetzt einen Wert in Spalte E änderst, wirst Du sehen, dass sich der betreffende Wert in Spalte I zu WAHR ändert.
 

osix

Bekanntes Mitglied
Vielen Dank für deine ausführliche Antwort !

ok, kann ich alles soweit nachvollziehen.

Wie mach ich jetzt die ganze Spalte E zu Text ? also das quasi meine Postleitzahlen, die mit Null anfangen können gleich als Text aufgefasst werden.

In Libre-Office.

Bisher hab ich die Spalte markiert, rechtgeklickt und dann "Zellen formatieren" gewählt und dann "Text" gewählt, bei Format steht vordefiniert "@", das hab ich so gelassen.

Genauso hab ich es gemacht und abgespeichert. Was mach ich falsch ?
 

osix

Bekanntes Mitglied
Nur ein Trick hilft: ich mache einen Buchstaben vor die Zahl und gleich wieder weg, dann springt der Wert von ISTTEXT() auf WAHR

Was ist denn das ? Das kann ich doch nicht "händisch" bei jeder Zahl machen.
 

mihe7

Top Contributor
Die naheliegende Lösung wäre, die Spalte einfach als Zahl einzulesen :)

Was ist denn das ? Das kann ich doch nicht "händisch" bei jeder Zahl machen.
Ich habs jetzt nicht ausprobiert, aber was funktionieren könnte, wäre die Werte in der Spalte auszuschneiden (Strg+X) und dann per "Inhalt einfügen" (Strg+Shift+V) wieder einzufügen, sofern die Spalte als Text formatiert wurde.
 

osix

Bekanntes Mitglied
Ich kann die Spalte nicht als Zahl einlesen weil Postleitzahl en mit Null anfangen können, das ist dann keine Zahl sondern Text.

Sagt jemand "automatisch e Zahlenerkennung" was bei libre Office ? Die könnte schuld sein daß sich das Spaltenformat sofort wieder auf Zahl zurück stellt, aber ich finde dazu in libre Office nichts.
 
K

kneitzel

Gast
Also nur kurz am Rande: Postleitzahl ist eine Zahl.

Die führende 0 ist lediglich eine Frage, wie die Zahl dann später dargestellt wird. Es ist also durchaus üblich, Daten in der korrekten Form zu speichern und dann halt bei der Anzeige auf ein Format String zurück zu greifen. Und es ist natürlich kein Thema, eine Zahl mit 5 Stellen (also mit führenden 0en) anzuzeigen: %05d dürfte das doch machen (Ohne Kontrolle aus dem Kopf heraus - aber das kannst Du ja ggf. schnell validieren!)
 

mrBrown

Super-Moderator
Mitarbeiter
Also nur kurz am Rande: Postleitzahl ist eine Zahl.

Die führende 0 ist lediglich eine Frage, wie die Zahl dann später dargestellt wird. Es ist also durchaus üblich, Daten in der korrekten Form zu speichern und dann halt bei der Anzeige auf ein Format String zurück zu greifen. Und es ist natürlich kein Thema, eine Zahl mit 5 Stellen (also mit führenden 0en) anzuzeigen: %05d dürfte das doch machen (Ohne Kontrolle aus dem Kopf heraus - aber das kannst Du ja ggf. schnell validieren!)
Würde ich widersprechen - sie besteht zwar auch Ziffern, sollte aber im Programm keine Zahl sein, es sei denn man will mit Postleitzahlen rechnen.
 

mihe7

Top Contributor
Prinzipiell lässt sich das Problem ja nur an zwei Stellen beheben, nämlich entweder in der Datenquelle oder im Code.

D. h. entweder man stellt sicher, dass die PLZ in der Eingabedatei einheitlich im gewünschten Format gespeichert ist oder man stellt sicher, dass das Einlesen mit den möglicherweise auftretenden Formaten umgehen kann. Da kann es dann durchaus sein, dass man Zahlen liest und mit %05d formatiert übernimmt.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
O xlsx Datei auslesen mit POI Apache liest keine LEERZELLEN Allgemeine Java-Themen 6
M xlsx File auslesen Exception occured Allgemeine Java-Themen 13
J xlsx Dateien lesen OHNE apache POI Allgemeine Java-Themen 6
M Java und *.xlsx Allgemeine Java-Themen 3
kodela StatusBar-Anzeigen auch in Log-Datei ausgeben Allgemeine Java-Themen 3
G Maven Projekt JAR-Datei Allgemeine Java-Themen 6
E XML - Datei Darstellung in IntelliJ als Baum Allgemeine Java-Themen 2
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
D Erste Schritte Mp3 Datei kann nicht von der Festplatte geöffnet werden - mit ChatGPT erstellt Allgemeine Java-Themen 7
J Filenotfoundexception obwohl Datei existiert Allgemeine Java-Themen 6
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2
S .exe Datei/Programm auslesen? Allgemeine Java-Themen 2
E Datei verschoben Event Allgemeine Java-Themen 3
D Datei mit "Kohsuke GitHub API" in Repository hochladen Allgemeine Java-Themen 2
S Bookmark HTML Datei einlesen, alle Links erhalten und manche editieren..? (aktuell JSoup) Allgemeine Java-Themen 4
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
G JavaFX Maven Projekt als .exe Datei exportieren Allgemeine Java-Themen 10
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
Neumi5694 Datei komprimiert Allgemeine Java-Themen 6
_user_q Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
_user_q Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
E java mithilfe url .jar datei öffnen Allgemeine Java-Themen 9
E Java .exe Datei mit args starten Allgemeine Java-Themen 2
W Bilder werden in App mit Jar-Datei nicht angezeigt Allgemeine Java-Themen 15
Master3000 Java Datei mehrmals einlesen Allgemeine Java-Themen 4
M Excel Datei Erstellen Allgemeine Java-Themen 2
E Input/Output Eigene Datei mit java öffnen Allgemeine Java-Themen 9
R Sonderzeichen aus Datei einlesen und in Datei ausgeben. Allgemeine Java-Themen 17
Tobero Download .jar von github lädt kaputte Datei runter Allgemeine Java-Themen 3
P Bat Datei in Java ausführen Allgemeine Java-Themen 2
S Verwendet Programmiersprache aus Quellcode - Datei ermitteln Allgemeine Java-Themen 6
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
J Jar-Datei ausführen Allgemeine Java-Themen 7
C Outlook msg-Datei Anhänge extrahieren Allgemeine Java-Themen 2
G Datei aus Ordner wählen, ohne den Dateinamen im Pfad angeben zu müssen Allgemeine Java-Themen 4
G Datei senden via Xmodem an Serial-Port Allgemeine Java-Themen 35
C Wav-Datei aus Jar laden? Allgemeine Java-Themen 11
L Best Practice Zip Datei aktualisieren Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
Gaudimagspam CSV-Datei auslesen in Java Allgemeine Java-Themen 7
S createTempFile erstellt keine temporäre Datei Allgemeine Java-Themen 13
Hatsi09 Jar datei ausführen verursacht NumberFormatException Allgemeine Java-Themen 9
kodela bestimmten Dateityp immer mit jar-Datei öffnen Allgemeine Java-Themen 17
N Arrayliste in eine Datei speichern Allgemeine Java-Themen 4
B .txt Datei erstellen und auslesen bzw. schreiben Allgemeine Java-Themen 6
J Öffnen eine jar-Datei Allgemeine Java-Themen 11
Dann07 MP3 Datei abspielen funktioniert nicht Allgemeine Java-Themen 6
H ArrayListe in CSV Datei speichern Allgemeine Java-Themen 6
O Aus JAR-Datei erstellte EXE-Datei funktioniert nicht Allgemeine Java-Themen 10
N Txt Datei auslesen. Allgemeine Java-Themen 5
B Datei/Ordner auf Server zugreifen/erstellen Allgemeine Java-Themen 2
MiMa Datei verschieben hat einen Fehler?? Allgemeine Java-Themen 20
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
P Input/Output entfernte Datei mit Java öffnen ohne Download Allgemeine Java-Themen 5
J Hilfe, Jar Datei kann nicht ausgeführt werden Allgemeine Java-Themen 2
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
J Fehlermeldung bei Ausführung von .jar-Datei Allgemeine Java-Themen 9
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
M Probleme jar datei. Allgemeine Java-Themen 2
F Datei in String-Array einlesen Allgemeine Java-Themen 8
O docx-Datei erzeugung mit DocXStamper funktioniert nicht Allgemeine Java-Themen 2
T Objekt mit String und Int aus TxT Datei erstellen Allgemeine Java-Themen 23
Bluedaishi Prüfen ob Datei noch geöffnet ist Allgemeine Java-Themen 59
I Temp-Datei wird nicht gelöscht Allgemeine Java-Themen 12
D ODS.Datei öffnet leider in Excel Allgemeine Java-Themen 3
L JavaFX JavaFX Chart in Apache Poi Excel Datei Allgemeine Java-Themen 2
D .txt Datei in .jar Datei speichern Allgemeine Java-Themen 3
ralfb1105 Blöcke aus Datei filtern/suchen und in neue Datei schreiben Allgemeine Java-Themen 10
M Daten aus MatLab Datei lesen Allgemeine Java-Themen 8
L SQL Datei in Eclipse erstellen Allgemeine Java-Themen 3
Drachenbauer Wie sorge ich dafür, dass mein Spiel die ini-Datei in der Resourcen-ordner des Projektes schreibt? Allgemeine Java-Themen 5
Trèfle Excel-Datei nicht speicherbar, da von Java zum Bearbeiten gesperrt. Allgemeine Java-Themen 3
N Datei Zeilenweise Einlesen, Versteckte Zeichen Allgemeine Java-Themen 5
L Excel Datei löscht sich selbst im Programm - Java Allgemeine Java-Themen 3
G Workupload datei mit Java Downloaden Allgemeine Java-Themen 6
H .jar Datei startet nicht richtig bei Doppelklick Allgemeine Java-Themen 11
S Hilfe bei dem Auslesen einer YAML Datei Allgemeine Java-Themen 8
M Java Eclipse- Datei exportieren Allgemeine Java-Themen 5
R jar-Datei funktioniert nicht Allgemeine Java-Themen 2
R .txt Datei einlesen und auf der Konsole ausgeben lassen Allgemeine Java-Themen 11
T Jar Datei nicht ausführbar Allgemeine Java-Themen 6
H jar-Datei mit java.exe anstatt mit javaw.exe ausführen Allgemeine Java-Themen 9
S Datei wird nicht gefunden Thread.currentThread().getContextClassLoader().getResourceAsStream() Allgemeine Java-Themen 1
A Steuerung von Spiel aus Datei lesen Allgemeine Java-Themen 0
Javafan01 .sh datei in Java ausführen Allgemeine Java-Themen 1
MiMa Speichern von Programmeinstellungen in Datei Allgemeine Java-Themen 7
J Ordner und Datei Struktur einer War Datei Allgemeine Java-Themen 1
J XML Datei mit installiertem Programm öffnen Allgemeine Java-Themen 7
L Weg um Datei zuzuordnen? Allgemeine Java-Themen 3
MiMa Datei kann nicht umbenannt oder verschoben werden ?? Allgemeine Java-Themen 17
S Input/Output Beste Möglichkeit einen String in einen Datei zu Schreiben Allgemeine Java-Themen 2
K Erste Schritte Start einer JAR Datei 2 Wege aber einmal nicht die volle Funktionlität Allgemeine Java-Themen 20
J Datei löschen, die Leerzeichen im Pfad hat Allgemeine Java-Themen 5
Aruetiise " in Datei schreiben Allgemeine Java-Themen 2
K Datei (CSV-ähnlich) in Java einlesen & mit teil der Daten Graphen erstellen Allgemeine Java-Themen 9
S Korrekte Pfadangaben damit eine .jar Datei unter Windwos läuft. Allgemeine Java-Themen 24
The Pi NetBeans Bilder in Jar Datei werden nicht angezeigt Allgemeine Java-Themen 7

Ähnliche Java Themen

Neue Themen


Oben