Problem mit JFileChooser -> Daten werden mit anführungsstriche in JTable geschrieben

deluxe1986

Mitglied
Hallo.
Ich hänge gerade an einem Problem bei dem JFileChooser und einer JTable. Ich gebe in die Tabelle Daten ein wobei eine für Zahlen vorgesehen ist. Danach wird die Datei in einer *.csv Datei gespeichert. Diese soll zu einem anderen Zeitpunkt wieder geladen und ergänzt werden. Hierbei kann es vorkommen, das es zwei gleiche Einträge gibt. Dann soll die Zahl verändert werden.

Soweit klappt das auch alles. Wenn ich die gespeicherte Datei jedoch in Excel verändere werden die Daten in der *.csv Datei in Anführungszeichen gespeichert. Wenn ich nun die Daten lade stehen die Zahlen auch in Anführungszeichen, wodurch ich die Zahlen nicht mehr verarbeiten kann. Das heißt ich müsste aus der *.csv Datei vorher die Anführungszeichen löschen ist dies irgendwie möglich, oder gibt es eine Möglichkeit andere Möglichkeit. Ich poste euch nochmal ein Beispiel meines FileChoosers zum Laden.

Java:
package Finanzen;
//
// Library Imports
import java.io.BufferedReader;
import java.io.File; 
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import javax.swing.*; 
 
@SuppressWarnings("serial")
public class OpenDlg2 implements java.io.Serializable
{ 
	/*Filechooser zum anzeigen des Öffnen Dialogs. Über diese Klasse wird das Öffnen
	 * der abgespeicherten Datei angezeigt.
	 * 
	 */
	public OpenDlg2()
	{
	  	//
		// Blatt 3
		
		//
		// Das Dialogfenster als Filechooser definieren
		JFileChooser chooser2 = new JFileChooser(); 
		//
		// Den Filechooser als Öffnen-Dialogfeld definieren
	  	int state2 = chooser2.showOpenDialog(null);
	  	//
	  	// Die gewählte Datei in den Programmcode übertragen
	  	File file2 = chooser2.getSelectedFile();
	  	//
	  	// Eine Integer Variable für die Spaltenanzahl angeben
	  	int k = 0;
	  	//
	  	// Ein String[] für die Daten angeben und initialisieren
	  	String[] rowData2 = null;
	  	//
		// Die Daten aus der Datei ins erste Tab übertragen
		try 
	  	{
			if (Tab3.table.getRowCount() != -1) 
			{
				//
				// Gesamte Tabelle Tab3 löschen
				for(int w=Tab3.table.getRowCount()-1;w>=0;w--) 
		    	{      
		    		Tab3.model.removeRow(w); 
		    	}
			}
			try
			{
				FileReader fr2 = new FileReader(file2);
				BufferedReader br2 = new BufferedReader(fr2);
				if (file2 != null && state2 == JFileChooser.APPROVE_OPTION)
			  	{
					String speicher = null;
					while((speicher = br2.readLine()) != null)
					{
						rowData2 = speicher.split(";");
						Tab3.model.addRow(rowData2);
						k = k + 1;
					}
			  	}
			}
			catch(NullPointerException npe)
			{
				
			}
		} 
	  	catch (FileNotFoundException e) 
	  	{
	  		JOptionPane.showMessageDialog(null, "Error! File not opened!");
		} 
	  	catch (IOException e) 
		{
	  		JOptionPane.showMessageDialog(null, "Error! File not opened!");
		}
	}
}

Die *.csv Datei sieht nach der Bearbeitung in OpenOffice so aus:

"ab";"cd";"500"
"ef";"gh";"400"

Muss aber so ausehen:

ab;cd;500
ef;gh;400


Danke im voraus.
 
S

SlaterB

Gast
dein Problem hat anscheinend nichts mit JFileChooser und sehr entfernt, quasi auch nichts mit JTable zu tun..,
du liest Text ein und trennst ihn nach Semikolon, entfernst aber nicht die Anführungszeichen, dann bleiben diese eben drin,
ist doch nicht überraschend?

keine der Standard-Java-Klassen kümmert sich um derartige Dinge, höchstens bei einem fertigen CSVParser a la
Simple demo of CSV parser class : CSV FileDevelopment ClassJava
bzw. ähnliche google-Ergebnisse könnte man das Abtrennen erwarten,
ansonsten dein String.split() um bisschen mehr Code erweitern
 
S

SlaterB

Gast
ja, das kannst du, wie ich auch geschrieben haben?

'entfernst aber nicht die Anführungszeichen'
'mehr Code'
usw.
 

deluxe1986

Mitglied
Aber wie habs mit einem neuen split versucht aber da kommt ganz großer Müll bei rum. Der Aufruf der Split Methode ist doch nur mit dem Parameter regex möglich. Stell mich da jetzt sicherlich ziemlich dämlich an :-D . Aber ich versteh einfach nicht wie ich die wegbekommen soll. Habs auch schon mit der replace und replaceAll versucht. Aber das klappt auch net :-(
 
S

SlaterB

Gast
verwende notfalls eben einfache Befehle, Schleife über alle Strings, die Split erzeugt hat, mit charAt() erstes + letztes Zeichen anschauen, substring()..,
Grundbefehle beherrschen, nicht nur abgehobenen Kram wie split() benutzen
 

deluxe1986

Mitglied
Mit charAt hab ich es auch schon versucht.

Java:
FileReader fr2 = new FileReader(file2);
				BufferedReader br2 = new BufferedReader(fr2);
				if (file2 != null && state2 == JFileChooser.APPROVE_OPTION)
			  	{
					String speicher = null;
					String ergebnis = null;
					while((speicher = br2.readLine()) != null)
					{
						for(int h = 0; h < speicher.length(); h++)
	            		{
	            			char character = speicher.charAt(h);
	            			String characterString = String.valueOf(character);
	            			if(characterString.equals("\""))
	            			{
	            				characterString = "";
	            			}	
	            			ergebnis = ergebnis + characterString;
	            		}
						rowData2 = speicher.split(";");
						Tab3.model.addRow(rowData2);
					}
			  	}
hat auch nüx gebracht :)

werd mir mal die substring methode mal anschauen.. :oops:
 
S

SlaterB

Gast
die Schleife in Zeile 9-18 macht ja ne Menge, aber den String ergebnis verwendest du danach nicht..,
das Split geht auf den Originalstring speicher

falls du stattdessen ergebnis splitten willst achte darauf, dass du die vorherigen Zeilen rauslöschst,
der wird immer länger

einen char kannst du auch direkt auf [c]== '"'[/c] vergleichen, ohne Escape, ohne String-Umweg
 

deluxe1986

Mitglied
So habs nach dann doch noch hinbekommen.
Falls es jemanden interessiert poste ich hier mal meine Lösung :

Java:
package Finanzen;
//
// Library Imports
import java.io.BufferedReader;
import java.io.File; 
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import javax.swing.*; 
 
@SuppressWarnings("serial")
public class OpenDlg2 implements java.io.Serializable
{ 
	/*Filechooser zum anzeigen des Öffnen Dialogs. Über diese Klasse wird das Öffnen
	 * der abgespeicherten Datei angezeigt.
	 * 
	 */
	public OpenDlg2()
	{
	  	//
		// Blatt 3
		
		//
		// Das Dialogfenster als Filechooser definieren
		JFileChooser chooser2 = new JFileChooser(); 
		//
		// Den Filechooser als Öffnen-Dialogfeld definieren
	  	int state2 = chooser2.showOpenDialog(null);
	  	//
	  	// Die gewählte Datei in den Programmcode übertragen
	  	File file2 = chooser2.getSelectedFile();
	  	//
	  	// Ein String[] für die Daten angeben und initialisieren
	  	String[] rowData2 = null;
	  	//
		// Die Daten aus der Datei ins erste Tab übertragen
		try 
	  	{
			if (Tab3.table.getRowCount() != -1) 
			{
				//
				// Gesamte Tabelle Tab3 löschen
				for(int w=Tab3.table.getRowCount()-1;w>=0;w--) 
		    	{      
		    		Tab3.model.removeRow(w); 
		    	}
			}
			try
			{
				FileReader fr2 = new FileReader(file2);
				BufferedReader br2 = new BufferedReader(fr2);
				if (file2 != null && state2 == JFileChooser.APPROVE_OPTION)
			  	{
					String speicher = "";
					while((speicher = br2.readLine()) != null)
					{
						String ergebnis = "";
						System.out.println(speicher);
						for(int i = 0; i < speicher.length(); i++)
						{
							char zwischenSpeicher = speicher.charAt(i);
							if(zwischenSpeicher == '"')
							{
								
							}
							else
							{
								String zwischenString = String.valueOf(zwischenSpeicher);
								ergebnis = ergebnis + zwischenString;
							}
						}
						rowData2 = ergebnis.split(";");
						Tab3.model.addRow(rowData2);
					}
			  	}
			}
			catch(NullPointerException npe)
			{
				
			}
		} 
	  	catch (FileNotFoundException e) 
	  	{
	  		JOptionPane.showMessageDialog(null, "Error! File not opened!");
		} 
	  	catch (IOException e) 
		{
	  		JOptionPane.showMessageDialog(null, "Error! File not opened!");
		}
	}
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
N JFileChooser bzw. FileDialog Problem AWT, Swing, JavaFX & SWT 10
Semox Swing JFileChooser: Problem Approve oder Cancel abzufangen AWT, Swing, JavaFX & SWT 7
G JFileChooser Problem AWT, Swing, JavaFX & SWT 4
T JFileChooser Problem AWT, Swing, JavaFX & SWT 3
G Problem mit JFileChooser AWT, Swing, JavaFX & SWT 6
H JFileChooser: das *.* Problem AWT, Swing, JavaFX & SWT 28
G Problem mit der Anzeige von jLabel. Unlesbar wenn der Text geändert wird. AWT, Swing, JavaFX & SWT 28
H 2D-Grafik Problem mit Paint AWT, Swing, JavaFX & SWT 1
S Layout - Problem AWT, Swing, JavaFX & SWT 1
Tassos JavaFX/Problem mit der Maussteuerung in Stackpane AWT, Swing, JavaFX & SWT 7
sserio Java Fx - Problem AWT, Swing, JavaFX & SWT 3
A Problem Spiel auf Panel der GUI zu bringen AWT, Swing, JavaFX & SWT 1
A JavaFX Controller Problem AWT, Swing, JavaFX & SWT 1
TheWhiteShadow JavaFX ListView Problem beim Entfernen von Elementen AWT, Swing, JavaFX & SWT 1
E LayoutManager Welcher Layout-Mix löst mein Problem? AWT, Swing, JavaFX & SWT 3
Umb3rus JavaFX Problem mit PropertyValueFactory: can not read from unreadable property AWT, Swing, JavaFX & SWT 1
T Problem mit paintComponent() AWT, Swing, JavaFX & SWT 17
AmsananKING Java Menü-Problem AWT, Swing, JavaFX & SWT 1
K JavaFX Resizing-Problem beim BorderLayout (Center Component) beim Arbeiten mit mehreren FXMLs AWT, Swing, JavaFX & SWT 2
G Instance OF Problem AWT, Swing, JavaFX & SWT 9
FrittenFritze Ein Problem mit der CSSBox, die Größe wird nicht angepasst AWT, Swing, JavaFX & SWT 5
M Problem mit dem Anzeigen von Frames im Vordergrund AWT, Swing, JavaFX & SWT 5
Badebay Problem mit JButton AWT, Swing, JavaFX & SWT 2
newJavaGeek Grid-Layout problem AWT, Swing, JavaFX & SWT 7
J JavaFX Löschen im Tabelview macht Problem AWT, Swing, JavaFX & SWT 15
JavaTalksToMe JavaFx ExekutorService Problem AWT, Swing, JavaFX & SWT 2
Zrebna Problem bei Eventhandling (Value soll nach jedem erneutem Klick gelöscht werden) AWT, Swing, JavaFX & SWT 4
B Problem mit JavaFX AWT, Swing, JavaFX & SWT 5
J css Problem AWT, Swing, JavaFX & SWT 5
B JavaFX habe mein Problem fett markiert AWT, Swing, JavaFX & SWT 2
A Swing Filter-Problem AWT, Swing, JavaFX & SWT 1
temi JavaFX Problem mit IntelliJ und JavaFx 11 unter XUbuntu AWT, Swing, JavaFX & SWT 3
L Java FX Problem mit Ubuntu 18 und JavaFx AWT, Swing, JavaFX & SWT 27
H JTable TableCellEditor-Problem AWT, Swing, JavaFX & SWT 0
kodela Swing Problem mit Warten-Dialog AWT, Swing, JavaFX & SWT 16
B JavaFx Scene Builder Problem AWT, Swing, JavaFX & SWT 2
B [Problem] Java öffnet Word-Datein nicht AWT, Swing, JavaFX & SWT 14
T DataBinding Problem AWT, Swing, JavaFX & SWT 5
Blender3D Problem mit € Symbol Font Gotham Windows 10 Swing AWT, Swing, JavaFX & SWT 11
T Problem mit JTable Sortierung AWT, Swing, JavaFX & SWT 2
J Problem mit Platfrom run later AWT, Swing, JavaFX & SWT 15
J Problem mit Platfrom run later AWT, Swing, JavaFX & SWT 0
D Swing SwingUtils / Thread Problem AWT, Swing, JavaFX & SWT 3
L JavaFX Problem beim Aufrufen einer Methode AWT, Swing, JavaFX & SWT 5
T Swing Problem mit Datum und FormattedTextField AWT, Swing, JavaFX & SWT 2
S AWT Java print dialog Problem AWT, Swing, JavaFX & SWT 0
olfibits JavaFX Problem mit HTMLEditor AWT, Swing, JavaFX & SWT 0
W SWT hover-background-problem with first column in TreeViewer AWT, Swing, JavaFX & SWT 0
M Problem mit Add JScrollPane AWT, Swing, JavaFX & SWT 25
Mario1409 Swing JTextArea scroll Problem AWT, Swing, JavaFX & SWT 0
N Swing Problem mit loop AWT, Swing, JavaFX & SWT 2
S Swing Problem mit Button und ActionListener AWT, Swing, JavaFX & SWT 5
S Swing & Clean und build Problem AWT, Swing, JavaFX & SWT 12
S JLabel setText() Problem AWT, Swing, JavaFX & SWT 6
I 2D-Grafik Problem beim Ändern der Farbe eine 2d Objekts AWT, Swing, JavaFX & SWT 3
G Swing Splitpane Problem AWT, Swing, JavaFX & SWT 1
F Problem mit der FXML Rectangle Shape AWT, Swing, JavaFX & SWT 2
N JavaFX Stranges Problem mit der Autoscroll-Eigenschaft von Textareas AWT, Swing, JavaFX & SWT 0
E Java FX FXML Problem mit html Scriptausführung AWT, Swing, JavaFX & SWT 2
J JavaFX Intersect Problem mit Shapes AWT, Swing, JavaFX & SWT 10
R JavaFX MediaPlayer AVI-Problem AWT, Swing, JavaFX & SWT 1
M Swing Problem mit ListCellRenderer AWT, Swing, JavaFX & SWT 7
D Problem mit JTable AWT, Swing, JavaFX & SWT 1
F GUI Auflösung ändern - Koordianten und Proportions Problem AWT, Swing, JavaFX & SWT 21
J Problem mit Button darstellung AWT, Swing, JavaFX & SWT 23
M Problem mit Layoutmanagern... Hilfe wäre sehr nett. AWT, Swing, JavaFX & SWT 2
S 2D-Grafik Problem mit Variablen AWT, Swing, JavaFX & SWT 4
7 JavaFX Problem beim Zeichnen eines Dreiecks in einem GUI AWT, Swing, JavaFX & SWT 6
M Swing AttributiveCellTableModel addRow() Problem AWT, Swing, JavaFX & SWT 1
J Swing Problem mit Graphics Methode AWT, Swing, JavaFX & SWT 4
N JavaFX Problem mit table multiple selection AWT, Swing, JavaFX & SWT 5
K CheckBox Problem AWT, Swing, JavaFX & SWT 5
Grevak DisplayMode Problem seit Windows 10 AWT, Swing, JavaFX & SWT 2
S Swing Eigene JComboBox Problem! AWT, Swing, JavaFX & SWT 1
B Swing Problem mit Bildpfad AWT, Swing, JavaFX & SWT 4
N Swing Problem beim Scrollen mit JScrollPane AWT, Swing, JavaFX & SWT 6
V Graphics g - drawOval problem mit background AWT, Swing, JavaFX & SWT 1
C AWT Problem mit Protokol Fenster AWT, Swing, JavaFX & SWT 0
M Swing pack() Problem mit Taskleiste AWT, Swing, JavaFX & SWT 4
N Swing Choice- Problem! AWT, Swing, JavaFX & SWT 8
Q "AWT-EventQueue-0" Exception Problem AWT, Swing, JavaFX & SWT 4
D jButton Problem, ein Rieser Button bedeckt das ganze frame AWT, Swing, JavaFX & SWT 1
A Problem: repaint() - Schleife AWT, Swing, JavaFX & SWT 3
J Anfänger GUI Problem bei der Ausführung eines sehr einfachen Programms AWT, Swing, JavaFX & SWT 2
P AWT Problem mit Platzierung (GridBagLayout) AWT, Swing, JavaFX & SWT 2
N Swing JTree Problem beim erstellen der Knoten AWT, Swing, JavaFX & SWT 0
N Swing CardLayout: Problem beim Wechsel zwischen den JPanels AWT, Swing, JavaFX & SWT 3
A Mini-Menu-Schriften. Ein Problem bei hohen DPI Zahlen AWT, Swing, JavaFX & SWT 2
Z Canvas in Frame einfügen. Problem mit 4-Gewinnt AWT, Swing, JavaFX & SWT 1
C Thread-/ Simulations- Problem AWT, Swing, JavaFX & SWT 18
G Swing Setvisible problem AWT, Swing, JavaFX & SWT 1
J JTabbedPane: close Button Problem AWT, Swing, JavaFX & SWT 2
Tom299 JavaFX -> fxmlLoader -> getResourceAsStream Problem AWT, Swing, JavaFX & SWT 1
T Problem: ComboBox und addItem AWT, Swing, JavaFX & SWT 5
M JTextArea wird nicht aktualisiert (ActionListener-Problem) AWT, Swing, JavaFX & SWT 1
T LayoutManager LookAndFeel-Problem AWT, Swing, JavaFX & SWT 4
F Problem mit Implementierung von Kollisionsabfrage AWT, Swing, JavaFX & SWT 5
vodkaz (javafx) Image Problem AWT, Swing, JavaFX & SWT 2
T Problem beim Zeichnen von Rechteck AWT, Swing, JavaFX & SWT 3
B JavaFX Problem bei Kamera / Group, gesamte Scene bewegt sich mit AWT, Swing, JavaFX & SWT 0

Ähnliche Java Themen

Neue Themen


Oben