procura posição de um string em outro
ind=strindex(haystack,needle,[flag]) [ind,which]=strindex(haystack,needle,[flag])
string. O string onde se procurará por ocorrências de
needle
string ou vetor de strings . O(s) string(s) a serem procurados
em haystack
vetor de índices
vetor de índices
string ("r" para expressão regular)
strindex
procura índices onde needle
(i)
é encontrado em haystack
Para cada k
existe um i
tal
que part(haystack,ind(k)+(0:length(needle(i))-1))
é o
mesmo string que needle(i)
. Se o argumento
which
for requerido, ele contém esses
i
. Quando se usa o terceiro parâmetro "r", needle deve
ser um string de expressão regular. Então, strindex irá corresponder a
haystack de acordo com as regras regulares expressas.
strindex
sem expressão regular é baseado no
algoritmo de Knuth-Morris-Pratt.
Este algoritmo é mais poderoso que aquele usado no Scilab 4.x. Em alguns casos especiais, o resultado pode ser diferente.
Exemplo:
// Scilab 5.x
-->[k,w]=strindex('aab',['a','ab'])
w = 1. 1. 2. k = 1. 2. 2.
// scilab 4.x
-->[k,w]=strindex('aab',['a','ab'])
w = 1. 1. k = 1. 2.
As regras de expressão regular são similares às da linguagem Perl. Para uma introdução rápida , ver http://perldoc.perl.org/perlrequick.html. Para um tutorial mais profundo , ver http://perldoc.perl.org/perlretut.html e para a página de referência, ver http://perldoc.perl.org/perlre.html