Philipp2112 Geschrieben 15. Januar 2016 Geschrieben 15. Januar 2016 Hallo zusammen, ich habe eine Datei (*.txt) in dieser verschiedene Daten zu einem Datensatz in 3 oder 4 Zeilen stehen, diese ich aber gerne zu einer zusammen fassen möchte. Aufbau der Datei: siehe Bild Anhang Nach dem verarbeiten sollte dann dieser Datensatz entstehen: 0815;541655;WW;1,20;Buchstabe A;Platz5; 08151;5416552;WW;1,30;Buchstabe B;Platz6; 08152;5416553;WW;1,40;Buchstabe C;Platz7; Könnt Ihr mir da helfen? Danke im vorraus. Philipp Zitieren
Gooose Geschrieben 15. Januar 2016 Geschrieben 15. Januar 2016 Fangen alle relevanten Datensätze mit einer Zahl an? Zitieren
Mttkrb Geschrieben 15. Januar 2016 Geschrieben 15. Januar 2016 Hallo, eine Möglichkeit wäre text.split(';')... und dann das IEnumerable mit einer where-clause von den CR/LF befreien. Anschließend das ganze wieder Zeilenweise zurückschreiben. Zitieren
Ultralisk Geschrieben 11. Februar 2016 Geschrieben 11. Februar 2016 Mir ist direkt aufgefallen, dass sich alle \n Newlines in der 1. und 2. Zeile befinden, während die 3. Zeile unverändert bleiben soll. Du kannst jedes Vorkommen von "\n" abzählen (dann %3 != 0 prüfen) und einen Substring für dessen Index ausführen. Zitieren
John_Clan Geschrieben 11. Februar 2016 Geschrieben 11. Februar 2016 Ich verstehe nicht wieso man hier mit einem Substring arbeiten sollte? Substring ist meiner Meinung nach immer eine schlechte Methode. Erstmal musst du dir einen Indikator suchen, wie ich sehe fängt der letzte Teil eines Datensatzes immer mit dem Platz an und wird mit einem Semikolon abgeschlossen. Also erweiterst du einen String solange, bis der o.g. Indikator gefunden wurde (string.contains) oder sowas. Wenn dieser Gefunden wurde, verarbeitest du den Datensatz und fängst mit der nächsten Zeile an, bis du den gesamten Content durchlaufen hast. Zitieren
CAEYO Geschrieben 17. Februar 2016 Geschrieben 17. Februar 2016 Würde einfach mit einem regulären Ausdruck arbeiten. Am Schluss deiner Einträge soll immer Platz und irgendeine Nummer stehen. Der Ausdruck sollte dann in etwas so aussehen: "Platz[0-9]{1,}". Anhand dessen würde ich den String dann splitten und einfach neu in die Datei schreiben lassen. Zitieren
lilith2k3 Geschrieben 18. Februar 2016 Geschrieben 18. Februar 2016 (bearbeitet) Sofern das Format "sauber" ist und Du keine Fehlertoleranz brauchst, bzw. Du genug Hauptspeicher hast versuchs mit diesem Hüftschuss: String = Lies Datei Teilstücke = String.SplitteBei('\n') For i=0; i<Teilstücke.length-2; i+=3 Schreibe Teilstücke+Teilstücke[i+1]+Teilstücke[i+2] in Datei Ende. Bearbeitet 18. Februar 2016 von lilith2k3 Zitieren
Pointerman Geschrieben 19. Februar 2016 Geschrieben 19. Februar 2016 Moin! zur Robustheit wurde im vorhergehenden Post schon etwas gesagt. Wenn Du "System.IO.ReadAllLines" verwendest, kannst Du Dir auch noch das Splitten verwenden. Dann bekommst Du ein Stringarray ohne Zeilenumbrüche, bei dem Du nur noch die Strings in neuer Reihenfolge aneinanderhängen musst (siehe Post von lilith2k3 ). Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.