Swing Tabellendaten exportieren

Status
Nicht offen für weitere Antworten.
M

mari0

Gast
Hallo,
gibt es eine eifnache möglichkeit, eine swing tabelle als *.doc, *.txt, *.html oder was auch immer zu exportieren, so dass die Tabellenformatierung weitestegehend erhalten bleibt.

Danke
 

Caffè Latte

Bekanntes Mitglied
Hi,

ich kenne das doc-Format nicht und txt kennt keine Tabellen. Mit HTML dürfte es am einfachsten sein.Oder was möchtest du jetzt geaus wissen?
 

EOB

Top Contributor
hi, also es gibt keine fertige klasse die das machen wuerde. ich wuerd auch sagen html. einfach zeile fuer zeile lesen und in html abspeichern. IMHO

gruesse
 

Leroy42

Top Contributor
Code:
<html>
<body>
...
<table>
  <tr>
    <td>Zelle der 1. Zeile, 1.Spalte</td>...<td>Zelle der 1. Zeile, m.Spalte</td>
  </tr>
    ...
  <tr>
    <td>Zelle der n. Zeile, 1.Spalte</td>...<td>Zelle der n. Zeile, m.Spalte</td>
  </tr>
</table>
...
</body>
</html>
 
M

mari0

Gast
also das weiß ich ,
also mit einem servlet write objekt das irgendwie machen
 

Caffè Latte

Bekanntes Mitglied
Hi,

ein Servlet? Ich dachte du hast 'ne Swing-Anwendung. Falls dem so ist, würde ich so vorgehen:

- Anzahl der Spalten und Zeilen ermitteln (Methoden getColumnCount und getRowCount des JTable-Objekts)
- ein Array mit den Headern erzeugen (die "Überschriften"). Über das TableModel der Tabelle kommst du da ran (getColumnName(index)).
- ein Datei-Objekt erzeugen und einen PrintWriter darauf
- Über den PrintWriter das HTML-Gerüst erzeugen
- In der ersten Schleife die Header schreiben (aus dem oben genannten Array)
- dann zwei verschachtelte for-Schleifen und zeilenweise die Spalten schreiben (myTable.getValueAt(zeile, spalte).toString())
- den HTML-Abschluss schreiben
- PrintWriter und File schliessen
- testen und debuggen

Hoffe es hilft ...
 
M

mari0

Gast
hmm nicht schlecht. vielen dank. mal gucken ob ich das zusammenschustern kann ;)
 

Caffè Latte

Bekanntes Mitglied
Hi,

ich hab das mal für eine csv-Export gemacht. Wenn du willst kannst du den Code haben, dann haste schon mal ein Gerüst ...
 

Caffè Latte

Bekanntes Mitglied
Hi,

hier mal der Quelltext:

Code:
/*
 * FileExport.java
 */

package exportUtils;

import java.io.File;
import java.io.FileWriter;
import java.io.PrintWriter;
import javax.swing.JFileChooser;
import javax.swing.JTable;

/**
 * Export table tableHeaders and data to a CSV file
 * 
 */
public class CsvExport {
    
    private JTable tableResult;
    private String[] tableHeaders;
    
    /**
     * Creates a new instance of FileExport
     * 
     * @param tableHeaders[] the headers from the JTable
     * @param tableResult the JTable object.
     */
    public CsvExport(String[] tableHeaders, JTable tableResult) {
        this.tableHeaders = tableHeaders;
        this.tableResult = tableResult;
    }
    
    /**
     * Write table tableHeaders and data to a file
     * selected from a file chooser.
     * 
     * @return null if no exception is thrown, otherwise the description of the exception 
     */
    public String writeCSV() {
        try {
            JFileChooser fileSelection = new JFileChooser();
            SimpleFileFilter csvFilter = new SimpleFileFilter("csv", "Komma getrennte Werteliste");
            fileSelection.setAcceptAllFileFilterUsed(false);
            fileSelection.addChoosableFileFilter(csvFilter);
            fileSelection.showDialog(null, "Exportieren");
            try {
                String fileName = fileSelection.getSelectedFile().toString();
                
                if (!fileName.substring(fileName.length()-4).toLowerCase().equals(".csv")) {
                    fileName += ".csv";
                }
                File exportFile = new File(fileName);
                if (exportFile != null){
                    PrintWriter pw = new PrintWriter(new FileWriter(exportFile.getAbsolutePath()));
                    int rows = tableResult.getRowCount();
                    int columns = tableResult.getColumnCount();
                    for (int i = 0; i < columns; i++){
                        pw.print(tableHeaders[i]);
                        if (i < columns-1) pw.print(";");
                    }
                    pw.println();
                    for (int i = 0; i < rows; i++) {
                        for (int j = 0; j < columns; j++){
                            pw.print(tableResult.getValueAt(i, j).toString());
                            if (j < columns-1) pw.print(";");
                        }
                        pw.println();
                    }
                    pw.close();
                }
            } catch (NullPointerException ex) {
                ex.printStackTrace();
                return null;
            }
            return null;
        } catch (Exception ex) {
            ex.printStackTrace();
            return(ex.toString());
        }
    }
}

Um deine Tabellendaten zu exportieren musst du eine Instanz von diesem CsvExport erstellen. Dem Konstruktor überginst du die Tabellenkopfdaten als String-Array und das JTable-Objekt. Den SimpleFileFilter findest du hier im Forum, einfach mal danach suchen (wenn du den Datei-Dialog überhaupt willst).

Bei Fragen einfach noch mal melden.
 
M

mari0

Gast
Vielen lieben Dank, hat mir sehr geholfen.
Hier kommt der Code nochmal zurück, wenn jemand sowas mal braucht.
Code:
public class CsvExport {
   
    private JTable tableResult;
    private String[] tableHeaders;
   
    /**
     * Creates a new instance of FileExport
     *
     * @param tableHeaders[] the headers from the JTable
     * @param tableResult the JTable object.
     */
    public CsvExport(String[] tableHeaders, JTable tableResult) {
        this.tableHeaders = tableHeaders;
        this.tableResult = tableResult;
    }
   
    /**
     * Write table tableHeaders and data to a file
     * selected from a file chooser.
     *
     * @return null if no exception is thrown, otherwise the description of the exception
     */
    public String writeCSV() {
        try {
            JFileChooser fileSelection = new JFileChooser();
            SimpleFileFilter csvFilter = new SimpleFileFilter("csv", "Komma getrennte Werteliste");
            fileSelection.setAcceptAllFileFilterUsed(false);
            fileSelection.addChoosableFileFilter(csvFilter);
            fileSelection.showDialog(null, "Exportieren");
            try {
                String fileName = fileSelection.getSelectedFile().toString();
               
                if (!fileName.substring(fileName.length()-4).toLowerCase().equals(".csv")) {
                    fileName += ".csv";
                }
                File exportFile = new File(fileName);
                if (exportFile != null){
                    PrintWriter pw = new PrintWriter(new FileWriter(exportFile.getAbsolutePath()));
                    
                    pw.print("<html><head><title></title></head><body><table width = '100%' border = '1'>");

                    int rows = tableResult.getRowCount();
                    int columns = tableResult.getColumnCount();
                    pw.print("<tr>");
                    for (int i = 0; i < columns; i++)
                    {
                        pw.print("<td>"+tableHeaders[i]+"</td>");
                        
                    }
                    pw.print("</tr>");
                    
                    
                    for (int i = 0; i < rows; i++)
                    {
                        pw.print("<tr>");
                        for (int j = 0; j < columns; j++)
                        {
                            pw.print("<td>"+tableResult.getValueAt(i, j).toString()+"</td>");                            
                        }
                        pw.print("</tr>");
                        
                    }
                    pw.print("</table></body></html>");
                    pw.close();
                }
            } catch (NullPointerException ex) {
                ex.printStackTrace();
                return null;
            }
            return null;
        } catch (Exception ex) {
            ex.printStackTrace();
            return(ex.toString());
        }
    }
}
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
XWing Jave swing overly benutzten. AWT, Swing, JavaFX & SWT 3
J Anzeige ID und Markierung für Knoten in Eclipse & Swing AWT, Swing, JavaFX & SWT 4
Juelin javax.swing in javafx AWT, Swing, JavaFX & SWT 1
A Eclipse 2023 und Swing AWT, Swing, JavaFX & SWT 4
W 2 JTables in einem Swing-Fenster? AWT, Swing, JavaFX & SWT 5
H Swing Componente zur Läufzeit ändern AWT, Swing, JavaFX & SWT 3
B Actionlistener mit Java Swing AWT, Swing, JavaFX & SWT 2
W Gibt es einen "automatischen Listener" in Swing oder JTable oder der ATM-Klasse? AWT, Swing, JavaFX & SWT 14
H Swing Buttons erst nach Klick sichtbar AWT, Swing, JavaFX & SWT 13
ExceptionOfExpectation Anpassung von JKomponentengrößen (Swing) AWT, Swing, JavaFX & SWT 3
thor_norsk AWT SWING Aufgabe AWT, Swing, JavaFX & SWT 7
U Zwei Fragen zu eienr Swing Aufgabe AWT, Swing, JavaFX & SWT 2
M Swing Bilder in Swing anzeigen AWT, Swing, JavaFX & SWT 9
H Swing , GridLayout, Größenbestimmung der Komponenten im Layout AWT, Swing, JavaFX & SWT 8
H Simple Animation mit Swing AWT, Swing, JavaFX & SWT 2
Guybrush Threepwood Einfachste Möglichkeit zum Abspielen eines Videos in Swing AWT, Swing, JavaFX & SWT 4
A Swing ProgressBar über 2 parallel laufende Threads AWT, Swing, JavaFX & SWT 2
M Swing GridLayout AWT, Swing, JavaFX & SWT 2
O return-Statement mit Swing AWT, Swing, JavaFX & SWT 6
O Ein Java-Programm mit Swing steuern AWT, Swing, JavaFX & SWT 1
Monokuma Swing zu JavaFX AWT, Swing, JavaFX & SWT 5
J Swing Slider AWT, Swing, JavaFX & SWT 11
G Thread starten Swing AWT, Swing, JavaFX & SWT 5
G Swing JPasswordField AWT, Swing, JavaFX & SWT 12
L Swing Button Farbe ändern/wechseln AWT, Swing, JavaFX & SWT 2
C Swing AWT GUI Anfänger Aufgabe AWT, Swing, JavaFX & SWT 7
W Inject bei einem Swing Frontend AWT, Swing, JavaFX & SWT 8
L Kommunikation zwischen Klassen / Konstruktoren bei Swing AWT, Swing, JavaFX & SWT 9
M Feldvalidierung swing AWT, Swing, JavaFX & SWT 4
E Swing Componenten werden nach Änderung des display modes verzerrt dargestellt AWT, Swing, JavaFX & SWT 8
D [Swing] Anordnung von Komponenten mit GridLayout Manager AWT, Swing, JavaFX & SWT 13
O Zukunft von Swing und JavaFX ? AWT, Swing, JavaFX & SWT 3
S Swing Fenster State Machine AWT, Swing, JavaFX & SWT 1
T Swing Swing an Bildschirm anpassen AWT, Swing, JavaFX & SWT 3
S Swing Panel wird nicht neu gezeichnet AWT, Swing, JavaFX & SWT 3
M Swing Java Swing/AWT Combobox Bug AWT, Swing, JavaFX & SWT 3
M Swing GUI mittels erben sowie variabler Dateninhalt AWT, Swing, JavaFX & SWT 1
W Swing Multitouch mit Swing AWT, Swing, JavaFX & SWT 6
S Swing-Applikation die ein Numpad nachbildet samt Keybindings..? AWT, Swing, JavaFX & SWT 5
S Swing Java Swing AWT, Swing, JavaFX & SWT 6
Blender3D Problem mit € Symbol Font Gotham Windows 10 Swing AWT, Swing, JavaFX & SWT 11
J Swing oder JavaFX AWT, Swing, JavaFX & SWT 21
D Swing Anwendung ohne JPanel erstellen AWT, Swing, JavaFX & SWT 1
D SQL Statements mit Java Swing benutzen AWT, Swing, JavaFX & SWT 4
Damtonix BufferStrategy flackert (Swing) AWT, Swing, JavaFX & SWT 9
D DatePicker für Java Swing AWT, Swing, JavaFX & SWT 2
B JavaFX oder swing AWT, Swing, JavaFX & SWT 3
T Java Swing - kleines Rechteck unter dem cursor AWT, Swing, JavaFX & SWT 5
L 2D-Grafik Swing paint|paintComponent AWT, Swing, JavaFX & SWT 2
L Swing Größe automatisch anpassen AWT, Swing, JavaFX & SWT 14
G Swing Swing Binding JList funktioniert nicht AWT, Swing, JavaFX & SWT 5
Blender3D Meine Swing Anwendung läuft unter Windows 10 und Ubuntu aber nicht auf Windows 7 AWT, Swing, JavaFX & SWT 16
B Bar Plot in Swing JPanel AWT, Swing, JavaFX & SWT 0
D Swing in Kombination mit JGraphX und JGraphT AWT, Swing, JavaFX & SWT 0
F main-Funktion bei Swing AWT, Swing, JavaFX & SWT 4
S Java Swing Print() method AWT, Swing, JavaFX & SWT 4
S Java Swing auf Windows Phone AWT, Swing, JavaFX & SWT 6
I JAVAFX - Übergabe der Inhalte an eine Scene - Wo ist der Vorteil gegenüber Swing? AWT, Swing, JavaFX & SWT 2
S Manuelles Menu in Swing AWT, Swing, JavaFX & SWT 3
T Custom Window ohne Swing / AWT / FX..?! AWT, Swing, JavaFX & SWT 1
MaxG. Swing Swing Komponenten zur Laufzeit hinzufügen AWT, Swing, JavaFX & SWT 2
Java_RY Bin Ratlos bzgl Malen in Swing AWT, Swing, JavaFX & SWT 5
offi Swing Shuttle List AWT, Swing, JavaFX & SWT 9
I Graph mit Swing zeichnen AWT, Swing, JavaFX & SWT 8
D Swing Swing Objekte sehen im Entwurf anders aus als beim Ausführen AWT, Swing, JavaFX & SWT 3
S Swing & Clean und build Problem AWT, Swing, JavaFX & SWT 12
javampir Swing repaint in JavaFX Anwendung AWT, Swing, JavaFX & SWT 3
K Mit JavaFX angefangen. Lohnt sich Swing? AWT, Swing, JavaFX & SWT 28
B Swing Update Swing Komponente bevor Methode startet. AWT, Swing, JavaFX & SWT 4
B Swing Tabelle(JTable) filtern swing GUI AWT, Swing, JavaFX & SWT 3
M Swing Swing-Widgets und paintComponent() AWT, Swing, JavaFX & SWT 2
B Swing WindowBuilde: Menu -> anderes Panel wechseln AWT, Swing, JavaFX & SWT 1
K eigener button in swing AWT, Swing, JavaFX & SWT 3
A JavaFX DatePicker in Swing beim Start nicht sichtbar AWT, Swing, JavaFX & SWT 2
windl Bufferstrategy in Swing nachstellen AWT, Swing, JavaFX & SWT 0
M Kamera in Java Swing einbinden AWT, Swing, JavaFX & SWT 4
Z Swing Swing und die Progressbar AWT, Swing, JavaFX & SWT 1
J Frage zur objektorentierten Swing Programmierung AWT, Swing, JavaFX & SWT 10
Xanny 2D-Grafik Beginner! Probleme mit Swing, Gprahics class und paint AWT, Swing, JavaFX & SWT 13
F Java Swing Rechteck in JPanel zeichnen AWT, Swing, JavaFX & SWT 7
N Swing Benötige Hilfe um ein Swing Canvas zu speichern AWT, Swing, JavaFX & SWT 4
stylegangsta JButton Fehelr javax.swing.ImageIcon.<init>(Unknown Source) AWT, Swing, JavaFX & SWT 24
RalleYTN Swing JavaFX VideoPlayer in Swing einbetten. Ich komm nicht an die Dimension des Videos! AWT, Swing, JavaFX & SWT 0
T swing läuft nur beding flüssig AWT, Swing, JavaFX & SWT 1
A Sonderzeichen bei Swing AWT, Swing, JavaFX & SWT 3
L DoubleBuffering unter Swing AWT, Swing, JavaFX & SWT 0
N Programm mit Swing und Thread, Figur bewegen sich nicht AWT, Swing, JavaFX & SWT 6
D Java Swing, Label lässt sich nicht mit Checkboxen/Knopf verändern AWT, Swing, JavaFX & SWT 2
J Swing Basics - JButton funktioniert nicht. AWT, Swing, JavaFX & SWT 1
J Swing/AWT | Dynamisch erzeugte Objekte ansprechen AWT, Swing, JavaFX & SWT 1
N JavaFX Umstieg von Swing auf Java FX AWT, Swing, JavaFX & SWT 6
J GUI Anfänger einfaches Program AWT, Swing, JavaFX & SWT AWT, Swing, JavaFX & SWT 3
M Swing Grundlegende Frage zu SWING mit WindowBuilder AWT, Swing, JavaFX & SWT 11
M Plugin oder eigenes Tool mit zB SWING AWT, Swing, JavaFX & SWT 2
Z Java-Swing : JComponent AWT, Swing, JavaFX & SWT 2
Z Swing Swing: Elemente werden doppel/verschoben gezeichnet, sind teils unsichtbar etc... AWT, Swing, JavaFX & SWT 10
S JComboBox aus anderer Klasse füllen (Java-Swing) AWT, Swing, JavaFX & SWT 0
N JComboBox in JTable [Swing] -> totaler UI-Einsteiger AWT, Swing, JavaFX & SWT 3
T Swing Kompatibilitätsproblem zwischen Swing und JavaFX AWT, Swing, JavaFX & SWT 4
M Layout-Probleme unter Swing AWT, Swing, JavaFX & SWT 5

Ähnliche Java Themen


Oben