Java Excel bestimmte Zellen auslesen (POI HSSF)

Status
Nicht offen für weitere Antworten.

Stefan2902

Aktives Mitglied
Hallo,

ich würde gerne ganz bestimmte Zellen einer Exceldatei auslesen. Teile dieser Zellen kann ich über den Zellennamen identifizieren. Von den anderen habe ich Zeilen- und Spaltennummer.

Daher meine Fragen:

a) Wie kann ich den Zelleninhalt einer benamten Zelle auslesen?
b) Wie kann ich den Zelleninhalt einer Zelle auslesen, deren Zeile und Spalte ich kenne, ohne durch das gesamte Sheet zu iterieren.

Hier mein Code:

Java:
package com.eet.lexifi;

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;

import org.apache.poi.hssf.usermodel.HSSFName;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

public class ReadNominations {

	/**
	 * @param args
	 * @throws IOException 
	 */
	public static void main(String[] args) throws IOException {
		// TODO Auto-generated method stub
		InputStream input = new FileInputStream("H:/LexiFi/test.xls");
		HSSFWorkbook wb = new HSSFWorkbook(input);
		HSSFSheet sheet = wb.getSheet("EON VPP Nomination");
		HSSFRow row = sheet.getRow(0);
		row.getCell(0).getNumericCellValue();

     
		HSSFName hssfn = wb.getName("customerid");
		System.out.print(hssfn.getRefersToFormula());
		
		
	}

}

Vielen Dank und Gruß
Stefan
 
S

SlaterB

Gast
b)
scheint einfach, du musst doch eh row und cell per Index auswählen, also genau die richtigen Indexe verwenden,

inwieweit benannte Zellen unterstützt werden, weiß ich nicht,
falls man wenigestens pro Zelle den Namen auslesen kann, würde es reichen, einmal über alle Zellen zu iterieren und eine Map Name -> Zelle aufzubauen
 

Stefan2902

Aktives Mitglied
b)
scheint einfach, du musst doch eh row und cell per Index auswählen, also genau die richtigen Indexe verwenden,

Kannst du mir mal einen Beispielcode dafür schicken, wie ich eine Zelle über Zeile und Spalte referenzieren kann?
 
S

SlaterB

Gast
Cell gesucht = sheet.getRow(rowNumber).getCell(column);

evtl. +-1,
und wenn du in Excel nur Spalte E kennst, dann musst du das erst in 5 umrechnen usw.
 

Stefan2902

Aktives Mitglied
Danke SlaterB. Das hat schonmal prima geholfen.

Ich habe zu diesem Thema noch zwei Fragen:

1. Ich lese eine Excelzelle aus, in der der Wert 06:00 steht. Die Zelle ist formatiert als Custom hh:mm. Wenn ich den Inhalt dieser Zelle mit

Java:
sheet.getRow(i + 33).getCell(4).toString()

auslese erhalte ich 31-Dec-1899. Wie ist es möglich den angezeigten Wert der Zelle (hier: 06:00) auszulesen?

2. Die folgenden Codezeilen

Java:
        HSSFName hssfn = wb.getName("customerid");
        System.out.print(hssfn.getRefersToFormula());

liefern mir die Referenz auf eine Zelle - in Form von $F$3 - die benamt ist. Ist es darüber hinaus möglich festzustellen, welche workbook names vergeben sind? In Excel sieht man diese unter: Insert > Names > Define.

Vielen Dank und Gruß
Stefan
 

faetzminator

Gesperrter Benutzer
Zu 1.:
Falls du das Format per POI auslesen kannst (hab ich noch nie benötigt), kannst du den String evtl. mit SimpleDateFormat formatieren, in dem du jenes als Format verwendest. Ansonsten müsstest du es hardcoden.
 
S

SlaterB

Gast
was genau in der Excel-Datei steht und wie man es auslesen könnte, kann ich ansonsten auch nicht erahnen,
bitte Test-Excel-Datei und Test-Programm posten, möglichst kurz ohne irgendwelche anderen Sachen

zu benannten Zellen weiß ich immer noch nix, falls die Frage (auch) an mich gerichtet war ;)
 

velaluka

Aktives Mitglied
Hallo,
wenn du die Zelle am Wickel hast und den Typen nicht kennst, musst du erst getCelltype aufrufen um danach die richtige Methode für den konkreten Typen aufzurufen.
 

Stefan2902

Aktives Mitglied
Hier ein Minimalbeispiel

Java:
	public static void main(String[] args) throws IOException {
		// TODO Auto-generated method stub

		InputStream input = new FileInputStream("H:/LexiFi/test123.xls");
		HSSFWorkbook wb = new HSSFWorkbook(input);
		HSSFSheet sheet = wb.getSheet("EON VPP Nomination");
		FileWriter writer = new FileWriter("H:\\LexiFi\\nominations.csv");

		System.out.print(sheet.getRow(2).getCell(3));
	}

Und im Anhang die Exceldatei.

Stefan
 
S

SlaterB

Gast
Java:
        for (int k = 2; k < 5; k++)
        {
            System.out.println("\nk: " + k);
            HSSFCell cell = sheet.getRow(k).getCell((short)3);
            System.out.println("d: " + cell.getNumericCellValue());
        }
Code:
k: 2
d: 0.25

k: 3
d: 0.6666666666666666

k: 4
d: 0.0
6.00 entspricht 0.25
16.00 entspricht 0.66

die Umrechnung dürfte doch klar sein, oder nicht?

was du mit 31-Dec-1899 meinst, kann ich nicht nachvollziehen, die Zelle ausgegeben ergibt bei mir
org.apache.poi.hssf.usermodel.HSSFCell@12d3205
vielleicht ne andere POI-Version
 

Stefan2902

Aktives Mitglied
Danke sehr. Ich erhalte die Doublewerte nun auch und kann diese mit folgendem Code auf einen Integer umwandeln:

Java:
		int value = new Double(sheet.getRow(33).getCell(4).getNumericCellValue() * 24).intValue();
		
		System.out.println(value);

Hat jemand noch eine Idee, wie ich nun das folgende Format hh:mm:ss bzw. aus diesem Integer "zaubern" kann?

Stefan
 
S

SlaterB

Gast
wenn du auf int rundest, können es ja nur ganze Stunden sein,
also
value +":00:00";
am Anfang evtl. noch ne 0, wenn value < 10,
fertig

oder etwas Date-mäßiger:
aus value*3600*1000 also long ein Date erstellen und an ein SimpleDateFormat zur Formatierung übergeben,
könnte allerdings aufwendig werden mit Zeitzone usw.

ich gehe dabei davon aus, dass die die Grundbegriffe von Date in Java bekannt sind (ms, 1970 usw), sonst im Lehrbuch nachzuschlagen ;)
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
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
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
T Java Excel Drop Down Formularsteuerelement Allgemeine Java-Themen 0
R Variablen per HSSF geheime Werte von JAVA an EXCEL Allgemeine Java-Themen 2
S Java & Excel Allgemeine Java-Themen 4
C Java Excel Button Allgemeine Java-Themen 2
P java tabelle auslesen - xls (excel) fehler Allgemeine Java-Themen 5
D Java Excel API - Schreiben in Excel lässt sich nicht über Makro starten Allgemeine Java-Themen 18
T DLL in Java einbinden (Quelltext aus Excel VBA) Allgemeine Java-Themen 5
B Excel Datei in einem Java Programm mit GUI darstellen Allgemeine Java-Themen 9
M Rein informativ - Daten aus Excel-Tabelle in Java-Programm importieren Allgemeine Java-Themen 3
J Java-Neuling und Excel - autsch! Allgemeine Java-Themen 16
F Formatieren von Zellen in Excel mit Java POI Allgemeine Java-Themen 5
M JAVA und Excel Allgemeine Java-Themen 8
G Java POI HSSF Excel Datei Gruppierung und Gliederung Allgemeine Java-Themen 2
ARadauer Excel Datei in Excel aus Java heraus öffnen Allgemeine Java-Themen 10
J Java-Com Bridge für Excel Allgemeine Java-Themen 4
R excel aus meiner java-applicatin öffnen Allgemeine Java-Themen 8
E Excel Dateien mit Java lesen? Allgemeine Java-Themen 4
S Java CSV und Excel. Allgemeine Java-Themen 5
K Java <-> Excel Api Allgemeine Java-Themen 3
N Von Java aus Excel ansteuern. Allgemeine Java-Themen 4
I Java Excel API Allgemeine Java-Themen 2
C java und excel? Allgemeine Java-Themen 4
L Java & Excel & EMail Allgemeine Java-Themen 2
Z java->schnittstelle->excel Allgemeine Java-Themen 2
P Drucken einer Excel Datei in Java Allgemeine Java-Themen 8
P Excel-Datei mit Java bearbeiten Allgemeine Java-Themen 2
D Excel-Datei mit Java auslesen Allgemeine Java-Themen 1
OnDemand Java Deployment Vaadin Allgemeine Java-Themen 3
D Hat Java eine Library um JavaScript auszuwerten? Allgemeine Java-Themen 2
Zrebna Wieso sind eigentlich JUnit-Tests in src/test/java platziert - nur Konvention? Allgemeine Java-Themen 7
N LlaMA, KI, java-llama.cpp Allgemeine Java-Themen 39
V Java-Codierungsherausforderung: Navigieren durch die Macken der Datumsmanipulation Allgemeine Java-Themen 2
E Output Fehler (Java-Programm Kuchen) Allgemeine Java-Themen 11
M java: unexpected type Allgemeine Java-Themen 2
harrytut Java Input/Output Tests Junit Allgemeine Java-Themen 3
B Java Discord bot auf ein Root Server? Allgemeine Java-Themen 1
BetziTheRealOne Java PKIX path building failed as non Admin Allgemeine Java-Themen 15
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
KonradN Java 21 Release Allgemeine Java-Themen 5
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
P Fehler: Hauptklasse Main konnte nicht gefunden oder geladen werden Ursache: java.lang.ClassNotFoundException: Main Allgemeine Java-Themen 24
K Java Anwendung machen Anleitung Allgemeine Java-Themen 5
G java.io.listFiles() Allgemeine Java-Themen 3
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
K Java-Projekt Allgemeine Java-Themen 11
K Java-Projekt Allgemeine Java-Themen 0
ruutaiokwu Welcher Browser unterstützt heutzutage noch Java Applets? Allgemeine Java-Themen 5
Jose05 Java-Klasse im extra cmd-Fenster ausführen Allgemeine Java-Themen 3
rode45e Java Threads Allgemeine Java-Themen 4
G java.io.listFiles() Allgemeine Java-Themen 2
N Java Dynamic Proxy Allgemeine Java-Themen 3
N Leichte Java Gegner Ki Allgemeine Java-Themen 10
A Java modul Problem Allgemeine Java-Themen 4
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
V Funktionale Schnittstelle in Java Allgemeine Java-Themen 3
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
berserkerdq2 Wenn ich bei Intelij javafx mit maven importieren will, muss ich das in die pom.xml reintun, aber warum noch in module-info.java? Allgemeine Java-Themen 3
KonradN Java 20 am 21. März Allgemeine Java-Themen 1
O Java Website Stock Bot Allgemeine Java-Themen 3
J Front-/Backend in Java Allgemeine Java-Themen 14
doopexxx JAVA Google Webcrawler Allgemeine Java-Themen 1
J JavaScript innerhalb eines Java Projekts ausführen Allgemeine Java-Themen 2
A Java Programm erstellen hilfe Allgemeine Java-Themen 10
G java.lang.NoClassDefFoundError: org/aspectj/lang/Signature Allgemeine Java-Themen 2
lalex1491 Java Aktienkurse nachfragen Allgemeine Java-Themen 4
J Class to link Java Allgemeine Java-Themen 4
V Wie funktioniert das Schlüsselwort "final" von Java? Allgemeine Java-Themen 19
mrStudent Inferenz JAVA Allgemeine Java-Themen 6
U URI Rechner (Java Script) Allgemeine Java-Themen 7
TheSkyRider Java Geburtsdatum Textfeld Allgemeine Java-Themen 7
mihe7 Java 19 JavaDocs: Browserintegration Allgemeine Java-Themen 0
Encera Gleichzeitiges Ausführen und verbinden von 2 Java-Klassen über die Eingabeaufforderung und Eclipse Allgemeine Java-Themen 21
H Java Rechner Programmierung der Mathematik Allgemeine Java-Themen 33
Lennox Schinkel Java Kara Auf einen Java Host laufen lassen Allgemeine Java-Themen 17
C Fußnoten von DocX mit Java Allgemeine Java-Themen 2
C Fußnoten in DocX mit Java Allgemeine Java-Themen 1
M Aussagenlogik in Java Programmieren Allgemeine Java-Themen 22
B Per Java Word Dokument schreiben? Allgemeine Java-Themen 8
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
KonradN Oracle übergibt (Java Teile der) GraalVM Community Edition an OpenJDK Community Allgemeine Java-Themen 2
Momo16 Brauche Hilfe - Java Projekt kann nicht erstellt werden Allgemeine Java-Themen 12
B Java mit command line und jars benutzen? Allgemeine Java-Themen 18
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2
B HTTP Allgemeine Fragen über Suchmaschine nutzen mit Java Allgemeine Java-Themen 20
Mick P. F. Wie kriege ich die Fehlermeldung "java: symbol lookup error: ..." weg? Allgemeine Java-Themen 11
K Nachhilfe Java Allgemeine Java-Themen 11
KonradN Java 19 Allgemeine Java-Themen 11
F IDEA IntelliJ Java Songliste erstellen Allgemeine Java-Themen 6
TheSepp Java bestimmtes Array auf den Wert 0 setzen Allgemeine Java-Themen 32
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
Sachinbhatt Sind alle Methoden in Java implizit virtuell Allgemeine Java-Themen 2
E Java und integrierte Grafikkarten Allgemeine Java-Themen 18

Ähnliche Java Themen

Neue Themen


Oben