Textdatei-Import

algebraiker

Aktives Mitglied
Hallo,

ich habe eine Textdatei und mich interessieren ausschließlich die Werte und nicht die Spalten. Ich habe die Textdatei angehängt.

Ich möchte nur folgende "Sachen haben":

| 01 |EM |2334454554 |210
| 01 |EM |3432342322 |310
| 01 |SE |3432434566 |310
| 01 |AS |7898797777 |310
| 01 |FK |7687867677 |310
| 01 |EM |2334454554 |210
| 01 |EM |3432342322 |310
| 01 |SE |3432434566 |310
| 01 |AS |7898797777 |310
| 01 |FK |7687867677 |310

.. und diese in ArrayListen speichern, aber first things first.

Wie kriege ich erstmal das


17.11.2011 Test 1
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Ausgaben
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
| Spalte 1|Spalte 2|Spalte 3|Spalte 4
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

alles vom Einlesen weg?

Ich dachte an irgendwie sowas wie, dass ich eine boolesche Methode schreibe, die überprüft, ob "Test" auftaucht und dann die nächsten Zeilen auch weghaut. Aber ist das überhaupt der richtige Weg? :bahnhof:


Java:
package importer;

import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

public class Importer {

	public static void main(String[] argv) {
		csvImport("C:/Daten/Testauszug.TXT");
	}

	public static List<Object> csvImport(String path) {
		FileReader file;
		List<Object> a = new ArrayList<Object>();
		try {
			String line = "";
			file = new FileReader(path);
			BufferedReader reader = new BufferedReader(file);
			int counter = 0;
			while ((line = reader.readLine()) != null) {
				
				if(containsString(line, "Test")) {
					System.out.println(line.trim());
					a.add(line);
				}
				break;

				// counter++;
				// if (counter > 6) {
				// String[] sep = line.split("[|]");
				// if (sep[13].trim().startsWith("000"))
				// {
				//
				// artNum.add(sep[13].trim());
				// artName.add(sep[14].trim());
				// artQuantity.add(Double.parseDouble(sep[17].trim().replaceAll("[,\\.]",
				// "")));
				//
				// String dateString = sep[10].trim();
				// String dateFormatString = "dd.MM.yyyy";
				// SimpleDateFormat format = new
				// SimpleDateFormat(dateFormatString);
				// Date newDate = format.parse(dateString);
				// artDate.add(newDate);
				// }
				// }
			}

		} catch (FileNotFoundException e) {
			throw new RuntimeException("File not found");
		} catch (IOException e) {
			throw new RuntimeException("IO Error occured");
		}

		return a;
	}
	
	private static boolean containsString( String s, String subString ) {
        return s.indexOf( subString ) > -1 ? true : false;
    }

}
 

Michael...

Top Contributor
Das hängt jetzt vom Aufbau der Textdatei ab. Wenn ausschließlich die relevanten Zeilen alle mit
Code:
|
gefolgt von irgendwelchen Ziffern anfangen, kann man das ja gezielt überprüfen.
 

algebraiker

Aktives Mitglied
Du meinst, du willst nur die in den Spalten enthaltenen Werte, aber nicht die Spaltenüberschriften?
Prüfe ab, ob eine Zeile mit | beginnt und keinen Text enthält; dann ist es eine Zeile mit Werten.

Ja genau, das möchte ich. Das ist ein guter Tipp!

Mein Versuch

Java:
public class Importer {

	public static void main(String[] argv) {
		csvImport("C:/Daten/Auftrag.TXT");
	}

	public static List<Object> csvImport(String path) {
		FileReader file;
		List<Object> a = new ArrayList<Object>();
		try {
			int counter = 0;
			String line = "";
			file = new FileReader(path);
			BufferedReader reader = new BufferedReader(file);
			while ((line = reader.readLine()) != null) {
				counter++;
				String[] sep = line.split("[|]");
				if(counter > 5) {
					System.out.println(sep[0]);
				}
			}

		} catch (FileNotFoundException e) {
			throw new RuntimeException("File not found");
		} catch (IOException e) {
			throw new RuntimeException("IO Error occured");
		}

		return a;
	}
}

liefert mir Nonsens. Ich dachte ich starte ab der 6. Zeile damit ich auch wirklich da anfange, wo ich es möchte. Aber kommt nicht viel dabei raus.
 

Michael...

Top Contributor
Ja genau, das möchte ich. Das ist ein guter Tipp!
Hey, den hatte ich zuerst ;-)

Das mit dem split kannst Du (ersteinmal) sparen. Lese erst einmal die Datei zeilenweise ein und prüfe, ob sie mit einem Pipe evtl. gefolgt von einer festen Anzahl an Leerzeichen beginnt. siehe String#startsWith(...).
Dann prüfst Du ob das darauf folgende Zeichen an Stelle x im String eine Ziffer ist...
 

algebraiker

Aktives Mitglied
Ups, sorry. Habe dein Posting aus Versehen überlesen. :D

Ich habe zum Testen ersteinmal die unnötigen Sachen entfernt und das hier versucht, was auch perfekt klappt.


Java:
package importer;

import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

public class Importer {

	public static void main(String[] argv) throws ParseException {
		csvImport("C:/Daten/Auftrag.TXT");
	}

	public static void csvImport(String path) throws ParseException {
		FileReader file;
		ArrayList<String> artNum = new ArrayList<String>();
		ArrayList<String> artName = new ArrayList<String>();
		ArrayList<Double> artPreis = new ArrayList<Double>();
		ArrayList<Date> artDate = new ArrayList<Date>();
		ArrayList<Date> artTime = new ArrayList<Date>();
		ArrayList<Double> artQuantity = new ArrayList<Double>();
		try {
			
			int counter = 0;
			String line = "";
			file = new FileReader(path);
			BufferedReader reader = new BufferedReader(file);
			while ((line = reader.readLine()) != null) {
				counter++;
				if(counter > 6) {
					String[] sep = line.split("[|]");
					if (sep[13].trim().startsWith("000")) 
					{
						artNum.add(sep[13].trim());
						
						artName.add(sep[14].trim());
						
						artPreis.add(Double.parseDouble(sep[16].trim().replaceAll("[,\\.]", "")));
						
						String dateString = sep[10].trim();
						String dateFormatString = "dd.MM.yyyy";
						SimpleDateFormat format = new SimpleDateFormat(dateFormatString);
						Date newDate = format.parse(dateString);
						artDate.add(newDate);
						
						artTime.add(null);
						
						artQuantity.add(Double.parseDouble(sep[17].trim().replaceAll("[,\\.]", "")));
					}
					
				}
			}
		} catch (FileNotFoundException e) {
			throw new RuntimeException("File not found");
		} catch (IOException e) {
			throw new RuntimeException("IO Error occured");
		}
	}
}

In den ArrayListen stecken nun genau die Daten drin, aaaaber ich will die Textdatei ja nicht bearbeiten. Wie würde denn das im Code aussehen Michael, dass ich die unnötigen Sachen einfach nicht betrachte? Ich komm irgendwie nicht drauf. :bahnhof:
 

langhaar!

Bekanntes Mitglied
Um unnötige Sachen nicht zu betrachten:

Java:
while ((line = reader.readLine()) != null) {
                counter++;
                if (line.indexOf('|') == -1)
                  continue;
                  ...

Bedeutet, wenn in einer Zeile kein | vorkommt, wird die nächste Iteration der while Schleife angesprungen. IndexOf liefert -1 wenn das Zeichen nicht im String ist.
 
E

emailundlos

Gast
Code:
| 01 |SE |3432434566 |310

So sieht also eine typische Zeile aus. Du musst dir Pattern und Matcher angucken (und vielleicht die String-Klasse), dann ergibt sich:

Java:
Patter p = Pattern.compile("(\\d{2})\\W+(\\w{2})\\W+(\\d{10})\\W+(\\d{2,3})");
Matcher m = p.matcher(irgendeinString);
if (m.find()) {
  // eine gültige Zeile
  // rausgeben: System.out.println(m.group(1) + "\t" + m.group(2) + "\t" + ......);
}

d: digit
w: word character
W: gegenteil
{}: eine Art Quantifizierer
(): match groups
 

algebraiker

Aktives Mitglied
Yes Baby, so funktioniert es perfekt.


Java:
package importer;

import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.text.ParseException;
import java.util.ArrayList;
import java.util.List;

public class Importer {

	private static List<String> SKIP_STRINGS = new ArrayList<String>();

	public static void main(String[] argv) throws ParseException {

		SKIP_STRINGS.add("|  Spalte1");

		csvImport("C:/Daten/text.TXT");
	}

	public static void csvImport(String path) throws ParseException {
		FileReader file;

		try {
			String line = "";
			file = new FileReader(path);
			BufferedReader reader = new BufferedReader(file);

			FileWriter writer = new FileWriter("C:/Daten/out.csv");
			writer.write("Nr;Name;Price;Date;Time;Quant\r\n");

			while ((line = reader.readLine()) != null) {
				// skip
				if (line.indexOf('|') == -1) {
					continue;
				}

				boolean isSkip = false;
				for (String s : SKIP_STRINGS) {
					if (line.startsWith(s)) {
						isSkip = true;
					}
				}
				if (isSkip) {
					continue;
				}
				
				System.out.println(line);

				String[] sep = line.split("[|]");
				if (sep[13].trim().startsWith("000")) {
					String a = sep[16].trim().replaceAll(
							"[.]", "");
					
					a = a.replaceAll("[,]", ".");
					
					String dateString = sep[10].trim();
					writer.write(sep[13].trim()
							+ ";"
							+ sep[14].trim()
							+ ";"
							+ Double.parseDouble(a)
							+ ";"
							+ dateString
							+ ";;"
							+ Double.parseDouble(sep[17].trim().replaceAll(
									"[,\\.]", "")) + "\r\n");
				}
			}
			writer.flush();
			writer.close();
		} catch (FileNotFoundException e) {
			throw new RuntimeException("File not found");
		} catch (IOException e) {
			throw new RuntimeException("IO Error occured");
		}
	}
}
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Best Practice Daten-Import /Trabsfomration aus Textdatei Java Basics - Anfänger-Themen 12
H Leere Zeilen in Textdatei löschen lassen Java Basics - Anfänger-Themen 5
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
N Textdatei aus Resourcen-Ordner eines Projekts/ jar-file lesen Java Basics - Anfänger-Themen 4
javapingu Jeglichen Inhalt einer Textdatei nach Zeile n löschen Java Basics - Anfänger-Themen 8
izoards Textdatei Human unreadable abspeichern Java Basics - Anfänger-Themen 17
A Eine Textdatei auslesen Java Basics - Anfänger-Themen 16
LeoDerKek Textdatei in JAR-File Java Basics - Anfänger-Themen 4
KogoroMori21 Textdatei einlesen im Array (Selection Sort Algorithmus) Java Basics - Anfänger-Themen 3
3 Textdatei Zeilenweise auslesen Java Basics - Anfänger-Themen 3
Ray19941 Über BlueJ Textdatei selbstständig erstellen lassen Java Basics - Anfänger-Themen 2
NeoLexx Datenströme Lesen und Schreiben einer Textdatei Java Basics - Anfänger-Themen 2
D Input/Output Mehrzeiligen String aus Textdatei erstellen Java Basics - Anfänger-Themen 5
M Datenbank oder Textdatei? Java Basics - Anfänger-Themen 4
X Textdatei: zwei-zeilenweise gleiche Zeilen rausschmeißen Java Basics - Anfänger-Themen 21
A Textdatei mit stream einlesen Java Basics - Anfänger-Themen 2
K Textdatei auslesen und über Mqtt schicken Java Basics - Anfänger-Themen 4
L Objekt aus Textdatei in ArrayList speichern Java Basics - Anfänger-Themen 4
J Wörter aus Textdatei suchen Java Basics - Anfänger-Themen 2
S Importieren einer Textdatei Java Basics - Anfänger-Themen 2
x-tshainge Innerhalb von Textdatei addieren Java Basics - Anfänger-Themen 9
Jinnai4 Werte in Textdatei ändern Java Basics - Anfänger-Themen 2
JDimi Textdatei mit beliebig vielen Zeilenumbrüchen erstellen Java Basics - Anfänger-Themen 2
it_is_all Bild-Pfad wird gefunden, nicht aber Textdatei-Pfad Java Basics - Anfänger-Themen 8
G Wert in Textdatei ersetzen? Java Basics - Anfänger-Themen 2
J Daten einer Textdatei in ein JTable importieren. Java Basics - Anfänger-Themen 3
C Input/Output Textdatei vom Java-Programm nicht geladen Java Basics - Anfänger-Themen 58
A Textdatei mit BufferedReader einlesen Java Basics - Anfänger-Themen 0
T Länge einer Textdatei Java Basics - Anfänger-Themen 11
S Übertragen einer Textdatei in ein 2d-Array Java Basics - Anfänger-Themen 2
N Integers aus Textdatei auslesen und mehrere Arrays erstellen Java Basics - Anfänger-Themen 9
T Textdatei öffnen und ans Ende scrollen Java Basics - Anfänger-Themen 11
J Textdatei filtern und bearbeiten Java Basics - Anfänger-Themen 1
C Textdatei oder doch eine Datenban Java Basics - Anfänger-Themen 15
J Input/Output Tilemap effizient speichern als Textdatei Java Basics - Anfänger-Themen 7
J Input/Output Zeile in Textdatei ändern Java Basics - Anfänger-Themen 14
M Textdatei(en) in .jar schreiben Java Basics - Anfänger-Themen 5
K Textdatei auslesen Java Basics - Anfänger-Themen 10
H Input/Output Inhalt einer GUI in Textdatei speichern Java Basics - Anfänger-Themen 1
K Erste Schritte Textdatei -> Array Java Basics - Anfänger-Themen 1
F Textdatei einlesen in ArryList (Objekte abspeichern?) Java Basics - Anfänger-Themen 4
F Problem mit Tabulatoren bei Zeilen zählen einer Textdatei Java Basics - Anfänger-Themen 17
G Erste Schritte Textdatei einlesen und in Array speichern Java Basics - Anfänger-Themen 5
F Textdatei einlesen und Zeilen zählen Java Basics - Anfänger-Themen 10
L Namen aus Textdatei auslesen Java Basics - Anfänger-Themen 1
E Textdatei kopieren funktioniert nicht Java Basics - Anfänger-Themen 12
M Zweidimensionales Array aus Textdatei gewinnen Java Basics - Anfänger-Themen 6
C Aus einer Textdatei Zahlen lesen mit Leerzeichen Java Basics - Anfänger-Themen 11
S Methoden Textdatei auslesen Java Basics - Anfänger-Themen 11
G Textdatei auf Dubletten prüfen Java Basics - Anfänger-Themen 8
T Textdatei Zeile löschen? Java Basics - Anfänger-Themen 4
T Textdatei beschreiben/bearbeiten Java Basics - Anfänger-Themen 4
S Textdatei einlesen und JFrame füllen Java Basics - Anfänger-Themen 14
C auslesen bestimmter werte einer textdatei und anschl. hineinschreiben in eine neue txt-datei. Java Basics - Anfänger-Themen 2
S Textdatei lesen, Methode gibt nur die letzte Zeile aus. Warum? Java Basics - Anfänger-Themen 5
C Einlesen in Array von Textdatei sehr langsam Java Basics - Anfänger-Themen 7
R Werte in eine Textdatei schreiben Java Basics - Anfänger-Themen 20
J Neue Zeile an bestimmter Stelle in Textdatei einfügen Java Basics - Anfänger-Themen 2
D Textdatei in geschachtelte Array speichern Java Basics - Anfänger-Themen 17
T Scanner für große Textdatei Java Basics - Anfänger-Themen 11
A Unterschied Textdatei und Quelltextdatei Java Basics - Anfänger-Themen 5
P Input/Output Textdatei einlesen - 1. Zeichen fehlt Java Basics - Anfänger-Themen 7
J Input/Output Textdatei in einer JAR lesen Java Basics - Anfänger-Themen 3
T Erste Schritte einzelne Wörter aus textdatei lesen... Java Basics - Anfänger-Themen 4
S Textdatei im Internet lesen und editieren Java Basics - Anfänger-Themen 2
J Textdatei einlesen und ausgeben - NullPointerException Java Basics - Anfänger-Themen 5
M Input/Output Objekte in einer Textdatei ablegen (Highscore) Java Basics - Anfänger-Themen 9
P CSV Daten in Textdatei Speichern Java Basics - Anfänger-Themen 3
K Input/Output Eingelesenedaten von Scanner als Textdatei ausgeben? Java Basics - Anfänger-Themen 2
N Input/Output Konsolenausgabe in Textdatei speichern/umleiten Java Basics - Anfänger-Themen 7
V Auf Textdatei in jar zugreifen Java Basics - Anfänger-Themen 3
A Textdatei einlesen - erstes Zeichen falsch Java Basics - Anfänger-Themen 20
S Methoden Textdatei Teil String auslesen Java Basics - Anfänger-Themen 3
H Zeile aus Textdatei lesen und in Textfield schreiben Java Basics - Anfänger-Themen 4
J durch drücken eines buttons text in einer textdatei speichern Java Basics - Anfänger-Themen 2
W letzte Zeile aus wachsender Textdatei auslesen Java Basics - Anfänger-Themen 5
M Datum aus einer Textdatei holen Java Basics - Anfänger-Themen 9
C Spalte einer Textdatei einlesen Java Basics - Anfänger-Themen 10
Fab1 Input/Output Textdatei auslesen Java Basics - Anfänger-Themen 4
O grosse Textdatei performant als string speichern Java Basics - Anfänger-Themen 8
P Mit offset aus Textdatei auslesen Java Basics - Anfänger-Themen 3
C Textdatei einlesen Java Basics - Anfänger-Themen 8
V Falsches Auslesen von Textdatei Java Basics - Anfänger-Themen 3
T Input/Output 20Mb Textdatei zeilenweise auslesen Java Basics - Anfänger-Themen 10
N Textdatei lesen mit Umlauten Java Basics - Anfänger-Themen 16
N In Textdatei speichern und auslesen Java Basics - Anfänger-Themen 18
M Textdatei einlesen Java Basics - Anfänger-Themen 3
M Liste in Textdatei schreiben Java Basics - Anfänger-Themen 7
B Input/Output Textdatei einlesen Windows / Linux Java Basics - Anfänger-Themen 2
F Textdatei einlesen Java Basics - Anfänger-Themen 7
C Textdatei einlesen -> Probleme Java Basics - Anfänger-Themen 3
K Input/Output Textdatei scheibchenweise auslesen Java Basics - Anfänger-Themen 8
S Textdatei stückweise einlesen Java Basics - Anfänger-Themen 7
D 1 Wort aus TextDatei auslesen Java Basics - Anfänger-Themen 3
J Jede Zeile der Textdatei in ListUI eintragen Java Basics - Anfänger-Themen 2
N Textdatei wird beim Speichern nicht überschrieben, sondern ergänzt Java Basics - Anfänger-Themen 4
A Double Array in TextDatei schreiben Java Basics - Anfänger-Themen 9
K Richtige Pfadangabe einer Textdatei Java Basics - Anfänger-Themen 7
B OOP Aus Textdatei auslesen Java Basics - Anfänger-Themen 11
P Textdatei auf erste Zeichenkette Prüfen... Java Basics - Anfänger-Themen 10

Ähnliche Java Themen

Neue Themen


Oben