AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Regex gesucht

Ein Thema von x000x · begonnen am 3. Nov 2006 · letzter Beitrag vom 3. Nov 2006
Antwort Antwort
Benutzerbild von x000x
x000x

Registriert seit: 21. Jan 2004
Ort: Bei Hamburg
308 Beiträge
 
Delphi XE2 Professional
 
#1

Regex gesucht

  Alt 3. Nov 2006, 11:11
Moin moin,

ich muss eine Textdatei parsen die folgendes Format hat
Code:
214;'WÜ';'Mustermann';'Muster';'D';'Teststr 5';'D';'99999';'Hamburg';1;'M';'2000-01-01 00:00:00';'J';'1998-01-01 00:00:00';12;6;15,29;'B';'12';'';'Sparkasse Testort';'12345678';'1234567';'Beliebiger Text der auch Zeichen wie ; enthalten kann';'1999-01-01 00:00:00';'';0;
Die Felder sind durch ; getrennt. Strings befinden sich in Hochkommas.

Ich suche nun eine Regex um auf jedes einzelne Feld zurgeifen zu können.
Peter
-= Gruss Peter =-
-= alias x000x =-
  Mit Zitat antworten Zitat
Benutzerbild von 3_of_8
3_of_8

Registriert seit: 22. Mär 2005
Ort: Dingolfing
4.129 Beiträge
 
Turbo Delphi für Win32
 
#2

Re: Regex gesucht

  Alt 3. Nov 2006, 11:15
[^;]{1}[']?(.*?)[']?[$;]{1}
Manuel Eberl
„The trouble with having an open mind, of course, is that people will insist on coming along and trying to put things in it.“
- Terry Pratchett
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#3

Re: Regex gesucht

  Alt 3. Nov 2006, 11:17
Sihe dazu auch ExplodeExplode, die Funktion zerlegt dir die Zeile in ein dynamisches Array. Ist in diesem Fall wohl einfachher.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von Khabarakh
Khabarakh

Registriert seit: 18. Aug 2004
Ort: Brackenheim VS08 Pro
2.876 Beiträge
 
#4

Re: Regex gesucht

  Alt 3. Nov 2006, 11:44
Zitat von 3_of_8:
[^;]{1}[']?(.*?)[']?[$;]{1}
Naja, nicht so wirklich.
Code:
(^|;)('([^']*?)'|([^']*?))(?=;)
Schon eher .
Eine Frage bleibt bei den Beispieldaten aber noch offen: Dürfen auch Hochkommata in einem Wert vorkommen, beispielsweise escaped?

@Luckie: Da ; auch mitten im einem Wert vorkommen kann, bleibt einem das Vor-/Nacharbeiten nicht erspart, womit Regexes wahrscheinlich wieder im Vorteil wären.
Sebastian
Moderator in der EE
  Mit Zitat antworten Zitat
Benutzerbild von 3_of_8
3_of_8

Registriert seit: 22. Mär 2005
Ort: Dingolfing
4.129 Beiträge
 
Turbo Delphi für Win32
 
#5

Re: Regex gesucht

  Alt 3. Nov 2006, 11:46
ARGH, ich hab schon zu lange nicht mehr mit dem Zeug gearbeitet.
Manuel Eberl
„The trouble with having an open mind, of course, is that people will insist on coming along and trying to put things in it.“
- Terry Pratchett
  Mit Zitat antworten Zitat
Benutzerbild von x000x
x000x

Registriert seit: 21. Jan 2004
Ort: Bei Hamburg
308 Beiträge
 
Delphi XE2 Professional
 
#6

Re: Regex gesucht

  Alt 3. Nov 2006, 13:35
Erst mal ein Danke an euch.
Zitat von Khabarakh:
Eine Frage bleibt bei den Beispieldaten aber noch offen: Dürfen auch Hochkommata in einem Wert vorkommen, beispielsweise escaped?
Ja dürfen. Die sind dann mit \ escaped.
Ich geb euch nochmal ein konkreteres Beispiel.
Code:
'Beliebiger Text der auch Zeichen wie ; oder \' bzw. \\ enthalten kann';'1999-01-01 00:00:00';'';0;
Peter
-= Gruss Peter =-
-= alias x000x =-
  Mit Zitat antworten Zitat
Benutzerbild von 3_of_8
3_of_8

Registriert seit: 22. Mär 2005
Ort: Dingolfing
4.129 Beiträge
 
Turbo Delphi für Win32
 
#7

Re: Regex gesucht

  Alt 3. Nov 2006, 13:39
Code:
(^|;)('(.*?)'|(.*?))(?=;)
Manuel Eberl
„The trouble with having an open mind, of course, is that people will insist on coming along and trying to put things in it.“
- Terry Pratchett
  Mit Zitat antworten Zitat
Benutzerbild von x000x
x000x

Registriert seit: 21. Jan 2004
Ort: Bei Hamburg
308 Beiträge
 
Delphi XE2 Professional
 
#8

Re: Regex gesucht

  Alt 3. Nov 2006, 14:05
Danke, es funktioniert
Peter
-= Gruss Peter =-
-= alias x000x =-
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:22 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz