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