Esta funcion lo que hace es buscar en el texto especificado un patron, y devolver la posicion en la que se encontro, pero permite mas funcionalidad, al poder elegir buscar de atras para adelante, o de poder dar la cantidad de coincidencias que hay.
Me imagino que se la podria optimizar, y se le puede agregar que no sea CASE sensitive, y varias cosas mas que puede me ponga a hacer cuando las necesite.
Código Delphi
[-]
function PosEx(const texto, patron : string; const veces : integer) : integer;
var vtexto, letra : string;
vecesb, cointot, posicion, termina : integer;
i, dir, posi, posi2 : integer;
begin
vtexto := texto;
vecesb := veces;
if veces = -1 then vecesb := 1;
if veces < -1 then vecesb := (veces*veces)+veces;
cointot := 0;
posicion := 0;
termina := 0;
if veces >= 0 then begin
i := 1;
dir := 1;
posi := 0;
posi2 := 1;
end
else begin
i := length(vtexto);
dir := -1;
posi := length(vtexto);
posi2 := 0;
end;
while (length(vtexto) > 0) and (termina = 0) do begin
letra := copy(vtexto,posi,1);
delete(vtexto,posi+posi2,1);
if (letra = patron) then begin
inc(cointot,1);
if (vecesb = cointot) then begin
posicion := i;
termina := 1;
end;
end;
inc(i,dir);
if veces < 0 then inc(posi,dir);
end;
if veces = 0 then
posicion := cointot;
PosEx := posicion
end;