Einzelnen Beitrag anzeigen

Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.033 Beiträge
 
Delphi 12 Athens
 
#7

Re: String nach Muster durchsuchen

  Alt 20. Jun 2009, 11:06
Zitat von Linguini:
In dem Thread habe ich leider nur Möglichkeiten gefunden, ob dieser String existiert, ich suche aber etwas das mir die Position bzw. gleich den ganzen String zurückgibt.
Zitat:
CompareWildStringEx liefert nicht TRUE bei erfolgreichem Vergleich, sondern die in den WildCards enthaltenen Zeichen/Strings.
merkt man vieleicht auch am Funktionsergebnis, welches rein zufällig Strings liefert

Delphi-Quellcode:
Unit Types;

Var S, Se: String;
  X: TStringDynArray;

S := 'FesterTeil|VeränderlicherTeil|FesterTeil';
X := CompareWildStringEx('FesterTeil|*|FesterTeil', S, []);
If X <> nil Then Se := X[0] Else Se := ''; // 0 = erstes/einziges *
ShowMessage('Se = "' + Se + '"');
ein Unterschied zu RegEx, welches standardmäßig mitten im String such ... meine Funktion verleicht immer den ganzen String:
Delphi-Quellcode:
S := 'irgendwas|FesterTeil|VeränderlicherTeil|FesterTeil|irgendwas';
X := CompareWildStringEx('*FesterTeil*FesterTeil*', S, []);
If X <> nil Then Se := X[1] Else Se := ''; // 1 = zweites *
ShowMessage('Se = "' + Se + '"');
ja und da nur je ein Ergebnis gesucht wird und man kein Offset angeben kann (wobei ein Offset nachzurüsten kein Problem wär, nur woher das Offset nehmen),
aber indem man das Suchmuster verlängert....
Delphi-Quellcode:
Var S, Ss, Se, Se2: String;
  i: Integer;
  X: TStringDynArray;

Begin

  S := 'irgendwas|FesterTeil1|VeränderlicherTeil1|FesterTeil2|irgendwas'
    + 'irgendwas|FesterTeil1|VeränderlicherTeil2|FesterTeil2|irgendwas';

  X := CompareWildStringEx('*FesterTeil1*FesterTeil2*FesterTeil1*FesterTeil2*', S, []);
  If X <> nil Then Begin
    Se := X[1]; // 1 = zweites *
    Se2 := X[3]; // 3 = viertes *
  End Else Begin
    Se := '';
    Se := '';
  End;

  ShowMessage('Se[0] = "' + Se + '" Se[1] = "' + Se2 + '"');



  S := 'irgendwas|FesterTeil1|VeränderlicherTeil1|FesterTeil2|irgendwas'
    + 'irgendwas|FesterTeil1|VeränderlicherTeil2|FesterTeil2|irgendwas'
    + 'irgendwas|FesterTeil1|VeränderlicherTeil3|FesterTeil2|irgendwas';

  i := -1;
  Ss := '*FesterTeil1*FesterTeil2*';
  While True do Begin
    X := CompareWildStringEx(Ss, S, []);
    If X = nil Then Break;
    Inc(i);
    Ss := '*FesterTeil1' + Ss; // Ss := '*FesterTeil1*FesterTeil2*' + Ss;
    Se := X[Length(X) - 2];

    ShowMessage('Se[' + IntToStr(i) + '] = "' + Se + '"');
  End;
man könnte das zwar noch optimieren, aber das laß ich jetzt erstmal
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat