was ist neu ¦  programmier tips ¦  indy artikel ¦  intraweb artikel ¦  informationen ¦  links ¦  interviews
 sonstiges ¦  tutorials ¦  Add&Win Gewinnspiel

Tips (1541)

Dateien (137)
Datenbanken (90)
Drucken (35)
Grafik (114)
IDE (21)
Indy (5)
Internet / LAN (130)
IntraWeb (0)
Mathematik (76)
Multimedia (45)
Oberfläche (107)
Objekte/
ActiveX (51)

OpenTools API (3)
Sonstiges (126)
Strings (83)
System (266)
VCL (242)

Tips sortiert nach
Komponente


Tip suchen

Tip hinzufügen

Add&Win Gewinnspiel

Werbung

41 Visitors Online


 
...mit der Pos Funktion rekursiv suchen?
Autor: Dirk Bögelspacher
Homepage: http://www.boegi.de
[ Tip ausdrucken ]  

Tip Bewertung (5):  
     


function PosN(Substring, Mainstring: string; n: Integer): Integer;

{
Function PosN ermittelt rekursiv - die N te Position von
"Substring" in "Mainstring". Ist der String nicht enthalten,
Ergebnis 0. Falls N zu hoch ist, wird das letzte gefundene
Vorkommen angezeigt. Funktioniert mit Chars und Strings
}

{
Function PosN get recursive - the N th position of "Substring" in
"Mainstring". Does the Mainstring not contain Substrign the result
is 0. Works with chars and strings.
}
begin
  if 
Pos(substring, mainstring) = 0 then 
  begin 
    
posn := 0; 
    Exit; 
  end
  else
  begin
    if 
n = 1 then posn := Pos(substring, mainstring) 
    else
    begin
      
posn := Pos(substring, mainstring) + posn(substring, Copy(mainstring,
        (Pos(substring, mainstring) + 1), Length(mainstring)), n - 1);
    end;
  end;
end;

//Beispiele / Examples

  
i := posn('s', 'swissdelphicenter.ch', 2);
  //  i=4



  
i := posn('x', 'swissdelphicenter.ch', 1);
  //  i=0


  
i := posn('delphi', 'swissdelphicenter.ch', 1);
  //  i=6

 

Bewerten Sie diesen Tipp:

dürftig
ausgezeichnet


Copyright © by SwissDelphiCenter.ch
All trademarks are the sole property of their respective owners