Zum Inhalt springen

Empfohlene Beiträge

Geschrieben

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

 

Notepad_Bild.JPG

Geschrieben

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.

 

  • 4 Wochen später...
Geschrieben

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.

Geschrieben

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. 

Geschrieben

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.

Geschrieben (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 von lilith2k3
Geschrieben

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 ).

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.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...