HSSF - JTable zu Excel exportieren

Status
Nicht offen für weitere Antworten.

mu

Aktives Mitglied
Hallo

Versuche grad ein HSSF Projekt zu realisieren.

Ich will meine JTable in ein Excelfile exportieren aber kriege das nicht richtig hin.
Das erstellen eines Excelfiles funktioniert einwandfrei, ich kann auch sheets erstellen und so.

Ich poste jetzt nicht mein ganzen Source da er viel zu gross ist.

Der Teil der nicht fertig ist:
Code:
/**
		 * ActionListener of 'exportButton'
		 */
		exportButton.addActionListener(new ActionListener()
		{

			@Override
			public void actionPerformed(ActionEvent arg0) 
			{
				sheet1 = workBook.getSheetAt(0);
				
				for(rowIterator = sheet1.rowIterator(); rowIterator.hasNext();)
				{
					row = (HSSFRow)rowIterator.next();
					for(cellIterator = row.cellIterator(); cellIterator.hasNext();)
					{
						cell = (HSSFCell)cellIterator.next();
						//Export??
					}
				}
			}
			
		});

Kennt sich da jemand besser aus? Eine kleine anleitung wie ich vorgehen muss, was bzw. falsch ist oder was noch fehlt.

/mu
 

ARadauer

Top Contributor
hab sowas schon mal geschrieben.
JTable2HSSFTable, der code liegt zuhause rum, ich poste ihn dir am abend
 
G

Gast

Gast
Hallo,

ich suche auch eine Möglichkeit von Jtable nach Excel .xls doch ich benutze wie gesagt für die Darstellung einer Tabelle eine JTable und kein Workbook dieser JExel api... geht das dennoch irgendwie?
 

ARadauer

Top Contributor
so das ist jetzt das was ich vor einem jahr mal geschrieben hab,
vielleicht könnt ihr ja damit was anfangen....

das table model, kann man sich jederzeit vom table hohlen

Code:
public class TableModelWriter {
 
      /**
       * schreibt ein table modell in eine excel datei
       * 
       * @param model
       * @param target
       * @param stelle
       * @throws FileNotFoundException
       * @throws IOException
       */
      public static void writeModelToExcel(TableModel model, File target,
                  String title) throws FileNotFoundException, IOException {
            POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream(target));
            HSSFWorkbook wb = new HSSFWorkbook(fs);
            HSSFSheet worksheets = wb.getSheetAt(0);
            
            
 
            int rows = model.getRowCount();
            int cols = model.getColumnCount();
            // titel erstellen
            HSSFRow excelRow = worksheets.getRow(0);
            if (excelRow == null) {
                  excelRow = worksheets.createRow(0);
            }
            HSSFCell excelCell = excelRow.getCell((short) 0);
            if (excelCell == null) {
                  excelCell = excelRow.createCell((short) 0);
            }
            excelCell.setCellValue(title);
            
            //überschriften erstellen
            excelRow = worksheets.getRow(1);
            if (excelRow == null) {
                  excelRow = worksheets.createRow(1);
            }
            for (int col = 0; col < cols; col++) {
                  excelCell = excelRow.getCell((short) col);
                  if (excelCell == null) {
                        excelCell = excelRow.createCell((short) col);
                  }
                  try {
                        excelCell.setCellValue(model.getColumnName(col));
                  } catch (Exception e) {
                        excelCell.setCellValue("");
                  }
            }                 
            
 
            for (int row = 0; row < rows; row++) {
                  excelRow = worksheets.getRow(row + 2);
                  if (excelRow == null) {
                        excelRow = worksheets.createRow(row + 2);
                  }
                  for (int col = 0; col < cols; col++) {
                        String sv=null;
 
                        Object o = model.getValueAt(row, col);
                        if (o instanceof CellValue) {
                             sv = ((CellValue)o).getValue();                            
                        }else if(o instanceof String){
                             sv = (String)o;
                        }else{
                            //das war für MEINEN Anwendungszweck nowtwendigt, das ist wahrscheinlich anzupassen.
                             sv = "0";
                        }
                        
                        
                        if (!sv.equalsIgnoreCase("0") && (sv.length() > 0)) {
                             excelCell = excelRow.getCell((short) col);
                             if (excelCell == null) {
                                   excelCell = excelRow.createCell((short) col);
                             }
                             try {
                                   float fv = Float.parseFloat(sv.replace(',', '.'));
                                   excelCell.setCellValue(fv);
                             } catch (Exception e) {
                                   excelCell.setCellValue(sv);
                             }
                        }
                  }
            }
            FileOutputStream fileOut = new FileOutputStream(target);
            wb.write(fileOut);
            fileOut.close();
      }
 
}
 
G

Gast

Gast
ich komm trotzdem nicht weiter, bezüglich meiner JTable.

Hier exportierst du ja garnichts, du schreibst lediglich den wert von 'sv' aus.

/mu
 
S

SlaterB

Gast
> Hier exportierst du ja garnichts, du schreibst lediglich den wert von 'sv' aus.

sv ist der Wert der jeweiligen Zelle, was willst du denn ansonsten exportieren?
 

ARadauer

Top Contributor
im jtable sind keine daten drin.
im Model sind die Daten

Code:
JTable table = new JTable();
table.getModel();

zeilen und spalten sind mal wichtig

Code:
int rows = model.getRowCount(); 
int cols = model.getColumnCount();

doppelte for schleife drüber gehen

Code:
 for (int row = 0; row < rows; row++) { 
... .....
                  for (int col = 0; col < cols; col++) {

und dann den wert besorgen

Code:
Object o = model.getValueAt(row, col);

usw...
 

mu

Aktives Mitglied
Stimmt das so in etwa?
Code:
for(rowIterator = sheet.rowIterator(); rowIterator.hasNext();)
{
	HSSFRow row = (HSSFRow)rowIterator.next();
	for(cellIterator = row.cellIterator(); cellIterator.hasNext();)
	{
	            HSSFCell cell = (HSSFCell)cellIterator.next();
	            //Export JTable??
	}
}

Hier iterier ich einfach über jede Zelle und übergebe dann so die Werte.
Geht das so?
 

ARadauer

Top Contributor
nein

willst du jetzt die excel datei als jtable haben oder das jtable als excel datei?`

warum iterierst du über die excel datei? die ist doch leer. du willst doch rein schreiben, oder?

hast du dir meinen code angesehen?
 

mu

Aktives Mitglied
So, ich will das thema nochmal hochkommen lassen (*kotz*)



ich hab ja 2 For-Schleifen die über die Exceltabelle gehen (oder?????)
Es sollen die daten aus meinem tableModel rein geschrieben werden.

vorsichtshalber das jeder mein schlimmes deutsch versteht.

hier mein kompletter code
ahm, da wo steht -> /* WICHTIGEr TEIL */
da weiss ich nicht weiter.

Code:
public TableToExcel()
	{
		super("JTable to Excel");
		setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		//setLayout(new FlowLayout());
		
		/**
		 * HSSFWorkbook
		 */
		workBook = new HSSFWorkbook();
		
		/**
		 * JPanel - upper, middle & lower
		 */
		upper = new JPanel();
		add(upper, BorderLayout.NORTH);
		middle = new JPanel();
		add(middle, BorderLayout.CENTER);
		lower = new JPanel();
		add(lower, BorderLayout.SOUTH);
		
		/**
		 * Tabledata
		 */
		String[] names = {"Ana", "Izabela", "Hendrik"};
		String[][] age = {{"25", "12", "21"},{"23", "32", "53"}};
		
		/**
		 * DefaultTableModel
		 */
		dtm = new DefaultTableModel(age, names);
		
		/**
		 * JTable
		 */
		table = new JTable(dtm);
		middle.add(table);
		
		
		/**
		 * Exportbutton
		 */
		exportButton = new JButton("Export to Excel");
		lower.add(exportButton);	
		
		/**
		 * ActionListener of 'exportButton'
		 */
		exportButton.addActionListener(new ActionListener()
		{
			@Override
			public void actionPerformed(ActionEvent arg0) 
			{
				int rows = dtm.getRowCount();
				int cols = dtm.getColumnCount();
				
				
				/* WICHTIGER TEIL */
				HSSFRow excelRow = sheet.getRow(0); 
	            if (excelRow == null) 
	            { 
	                  excelRow = sheet.createRow(0); 
	            } 
	            
	            HSSFCell excelCell = excelRow.getCell((short) 0); 
	            if (excelCell == null) 
	            { 
	                  excelCell = excelRow.createCell((short) 0); 
	            } 

				for(int row = 0; row < rows; row++)
				{
					excelRow = sheet.getRow(row + 2); 
					if (excelRow == null) 
					{
						excelRow = sheet.createRow(row + 2);
					} 

					for(int col = 0; col < cols; col++)
					{
						Object obj = dtm.getValueAt(rows, cols);
						
					}
				}
				/* WICHTIGER TEIL ENDE */
				
				
				/**
				 * FileOutputStream
				 */
				fileOut = null;
				try 
				{
					fileOut = new FileOutputStream("WorkBook.xls");
				}
				catch (FileNotFoundException e) 
				{
					e.printStackTrace();
				}
				
				try 
				{
					workBook.write(fileOut);
				} 
				catch (IOException e) 
				{
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				
				try 
				{
					fileOut.close();
				} 
				catch (IOException e) 
				{
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}
		});
	}
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
R POI HSSF liesst in Excel Formel statt Ergebnis Java Basics - Anfänger-Themen 4
J HSSF POI in JCreator einbinden Java Basics - Anfänger-Themen 4
J Winzige Frage bezüglich leeren Zellen (HSSF) Java Basics - Anfänger-Themen 14
A Apache POI - HSSF vs. XSSF Problem Java Basics - Anfänger-Themen 4
G POI/HSSF tutorial Java Basics - Anfänger-Themen 25
T POI HSSF - Datum auslesen? Java Basics - Anfänger-Themen 2
K Mit POI-HSSF Diagramme aus XLS- Importieren Java Basics - Anfänger-Themen 2
richis-fragen JTable den angezeigten WERT nicht den Wert aus dem Model ausgeben. Java Basics - Anfänger-Themen 3
richis-fragen JTable Header ausgeblendete (width = 0) nicht per mouseDragged aufziehen. Java Basics - Anfänger-Themen 9
richis-fragen JTable sowohl Spaltennamen wie auch Spaltenbeschriftungen Java Basics - Anfänger-Themen 7
richis-fragen JTable effektiv angezeigter Text ausgeben nicht Inhalt vom Model Java Basics - Anfänger-Themen 9
G JTable Listselectionlistener friert das Programm ein Java Basics - Anfänger-Themen 8
Mady Daten von JList & Combobox in JTable adden Java Basics - Anfänger-Themen 2
W Liste mit Listen in JTable darstellen Java Basics - Anfänger-Themen 1
J Zelleninhalt einer Jtable löschen Java Basics - Anfänger-Themen 2
E JTable einzelne Zelle färben Java Basics - Anfänger-Themen 2
thobren jtable arraylist Java Basics - Anfänger-Themen 12
thobren JTable Icon Java Basics - Anfänger-Themen 1
R Compiler-Fehler JTable mit XML befüllen | The constructor JTable(Object[], String[]) is undefined Java Basics - Anfänger-Themen 10
H Kapselung JProgressBar in JTable, aber getValueAt() greift nicht Java Basics - Anfänger-Themen 7
G JTable, Zeile auswählen und Ergebnis an Schaltfläche übergeben Java Basics - Anfänger-Themen 4
J Jtable Eingabe nach Klick ausserhalb der Tabelle übernehmen Java Basics - Anfänger-Themen 6
J JTable Spalteninhalt löschen Java Basics - Anfänger-Themen 1
J JTable Titel wird nicht angezeigt Java Basics - Anfänger-Themen 6
B jTable Spalte summieren Java Basics - Anfänger-Themen 7
N JTable auslesen Java Basics - Anfänger-Themen 6
O JTable in Excel mit Farben Java Basics - Anfänger-Themen 8
O Kommentar auf JTable Zelle Java Basics - Anfänger-Themen 2
M Jtable Reenderer Java Basics - Anfänger-Themen 0
O Popoup Menü im JTable richtig anzeigen Java Basics - Anfänger-Themen 6
M Jtable änderung updaten Java Basics - Anfänger-Themen 2
O JTable Suchfunktion Java Basics - Anfänger-Themen 2
M jTable bekommt null Java Basics - Anfänger-Themen 1
M JTable an andere Klasse übergeben Java Basics - Anfänger-Themen 2
M Datenbank in jTable Laden Java Basics - Anfänger-Themen 49
M Klasse in JTable einfügen Java Basics - Anfänger-Themen 7
S JTable Java Basics - Anfänger-Themen 16
S JTable mit Daten füllen Java Basics - Anfänger-Themen 7
L JTable Tagebuch Spaltenhöhe verändern Java Basics - Anfänger-Themen 3
S JTable - Filter an anderen Colums Java Basics - Anfänger-Themen 2
R JTable Suchfunktion mit SQL Daten Java Basics - Anfänger-Themen 2
C JTable update mit MySQL Datenbank Java Basics - Anfänger-Themen 1
C Best Practice JTable in MVC Pattern Java Basics - Anfänger-Themen 7
J Daten einer Textdatei in ein JTable importieren. Java Basics - Anfänger-Themen 3
A zykl. Aktualisierne JTable Java Basics - Anfänger-Themen 9
C Endlosschleife bei füllen von Daten im JTable Java Basics - Anfänger-Themen 5
C Werte aus JTable auslesen Java Basics - Anfänger-Themen 4
A Probleme beim zykl. aktulisieren von Daten in JTable Java Basics - Anfänger-Themen 3
V JTable welcher Listener ? Java Basics - Anfänger-Themen 7
D Falsche Zeile wird in JTable gelöscht Java Basics - Anfänger-Themen 6
D MySQL Abfrage in JTable speichern Java Basics - Anfänger-Themen 43
D JTable Zeile wird nicht in MySQL gelöscht Java Basics - Anfänger-Themen 16
D JTable Zeilen löschen Java Basics - Anfänger-Themen 5
C Klassen JTable wird ohne Header aufgebaut Java Basics - Anfänger-Themen 6
K (JTable) Text einer Zelle auf der linken Seite kürzel Java Basics - Anfänger-Themen 2
B Kniffel JTable Java Basics - Anfänger-Themen 5
N JTable flackert Java Basics - Anfänger-Themen 8
T JTable Daten aus txt datei Java Basics - Anfänger-Themen 3
J ArrayList wird in JTable falsch angezeigt Java Basics - Anfänger-Themen 0
J Eintragen von Personen in JTable Java Basics - Anfänger-Themen 4
X JTable mit grünen und roten Punkten Java Basics - Anfänger-Themen 2
LexeB4F DEL --> JTable Zelleninhalt Java Basics - Anfänger-Themen 3
R JTable Auslesen Java Basics - Anfänger-Themen 1
Crazynet jTable erste Zeile mit deffinierten Werten Java Basics - Anfänger-Themen 0
K Collections Sortieren nach zweiter Spalte in JTable Java Basics - Anfänger-Themen 18
J JTable Wert gleich überschreiben Java Basics - Anfänger-Themen 6
S Zeile entfernen aus JTable Java Basics - Anfänger-Themen 15
S JTable clonen Java Basics - Anfänger-Themen 5
H Best Practice PDF JTable Java Basics - Anfänger-Themen 4
S In JTable Zeile selektieren mit Mausklick Java Basics - Anfänger-Themen 16
D JTable Probleme beim Sortieren von Zahlen. Java Basics - Anfänger-Themen 6
M JTable mit XML datei befüllen Java Basics - Anfänger-Themen 1
F Zeile bei JTable hinzufügen Java Basics - Anfänger-Themen 6
K JTable Bild einfügen Java Basics - Anfänger-Themen 1
M [JTable] getValue throws ArrayOutOfBoundException Java Basics - Anfänger-Themen 1
B JTable - Highlighter ??? Java Basics - Anfänger-Themen 3
S JTable LinkedList <Objekt> befüllen Java Basics - Anfänger-Themen 1
S JTable dynamisch mit Datenbankinhalten füllen Java Basics - Anfänger-Themen 6
W JTable mit einem JButton-Array füllen Java Basics - Anfänger-Themen 4
O JScrollPane zu gross für JTable Java Basics - Anfänger-Themen 2
L JTable Row selected -> fireTableDataChange do nothing. Java Basics - Anfänger-Themen 3
E JTable + TableModel updaten? Java Basics - Anfänger-Themen 1
O java.lang.IndexOutOfBoundsException JTable autoSort Java Basics - Anfänger-Themen 5
F JTable adding Row Java Basics - Anfänger-Themen 5
P jTable getColumnClass, mit unterschiedlichen Klassen in einer Column? Java Basics - Anfänger-Themen 5
M Eingabe in JTable bei Eingabe korrigieren Java Basics - Anfänger-Themen 2
Z jtable problem (das tausendste??) Java Basics - Anfänger-Themen 12
J JTable Java Basics - Anfänger-Themen 7
T JTable Java Basics - Anfänger-Themen 2
T JTable einzelne Zeilen löschen Java Basics - Anfänger-Themen 3
S Farbe eine Zeile in JTable ändern, wenn JButton geklickt wurd Java Basics - Anfänger-Themen 4
Uzi21 jTable / Inhalt speichern Java Basics - Anfänger-Themen 2
M Problem mit JTable und Model Java Basics - Anfänger-Themen 3
F Methoden JTable + 2 For-Schleifen Java Basics - Anfänger-Themen 4
C jtextfield und jtable Java Basics - Anfänger-Themen 34
X JTable mit Inhalten aus JTextField o.ä. füllen Java Basics - Anfänger-Themen 4
G JTable: SelectionListener Problem Java Basics - Anfänger-Themen 2
G JTable: Werte in Tabelle direkt ansprechen Java Basics - Anfänger-Themen 3
S Icons in JTable per ResultSet Java Basics - Anfänger-Themen 5
G Spalte in JTable unsichtbar machen, Zugriff auf Daten ermöglichen Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben