strripos

(PHP 5, PHP 7, PHP 8)

strriposEncontra a posição da última ocorrência de uma substring em uma string, insensível a miúsculas/minúsculas

Descrição

strripos(string $haystack, string $needle, int $offset = 0): int|false

Encontra a posição numérica da última ocorrência de needle na string haystack.

Diferentemente de strrpos(), strripos() é insensível a miúsculas/minúsculas.

Parâmetros

haystack

A string onde a substring será procurada.

needle

A substring procurada.

Antes do PHP 8.0.0, se needle não for uma string, ela será convertida para um número inteiro e aplicada como o valor ordinal de um caractere. Este comportamento tornou-se defasado a partir do PHP 7.3.0 e depender dele é altamente desaconselhado. Dependendo do comportamento pretendido, o parâmetro needle deve ser explicitamente convertido em string ou uma chamada explícita para chr() deve ser realizada.

offset

Se zero ou positivo, a pesquisa é realizada da esquerda para a direita pulando os primeiros offset bytes de haystack.

Se negativo, a pesquisa é realizada da direita para a esquerda pulando os últimos offset bytes de haystack e pesquisando pela primeira ocorrência de needle.

Note:

Efetivamente, é o mesmo que procurar pela última ocorrência de needle antes dos últimos offset bytes.

Valor Retornado

Retorna a posição onde a string procurada existe relativamente ao início da string haystack (independente da direção de busca ou do deslocamenteo).

Note: A posições na string iniciam em 0, e não em 1.

Retorna false se a string não for encontrada.

Warning

Esta função pode retornar o valor booleano false, mas também pode retornar um valor não booleano que pode ser avaliado como false. Leia a seção sobre Booleanos para mais informações. Use o operador === para testar o valor retornado por esta função.

Registro de Alterações

Versão Descrição
8.2.0 A redução de todas as letras a maiúsculas ou minúsculas não depende mais da localidade definida com setlocale(). Somente a redução de todas as letras ASCII a maiúsculas ou minúsculas será feita. Os bytes não ASCII serão comparados por seu valor de byte.
8.0.0 O parâmetro needle agora aceita uma string vazia.
8.0.0 Passar int no parâmetro needle não é mais suportado.
7.3.0 Passar um int no parâmetro needle tornou-se defasado.

Exemplos

Example #1 Um exemplo simples de strripos()

<?php
$haystack = 'ababcd';
$needle   = 'aB';

$pos      = strripos($haystack, $needle);

if ($pos === false) {
    echo "Desculpe, não encontramos ($needle) em ($haystack)";
} else {
    echo "Parabéns!\n";
    echo "Encontramos a última ocorrência de ($needle) em ($haystack) na posição ($pos)";
}
?>

O exemplo acima produzirá:

Parabéns!
   Encontramos a última ocorrência de (aB) em (ababcd) na posição (2)

Veja Também

  • strpos() - Encontra a posição da primeira ocorrência de uma substring em uma string
  • stripos() - Encontra a posição da primeira ocorrência de uma substring em uma string, de forma insensível a maiúsculas/minúsculas
  • strrpos() - Encontra a posição da última ocorrência de uma substring em uma string
  • strrchr() - Encontra a última ocorrência de um caractere em uma string
  • stristr() - strstr insensível a maiúsculas/minúsculas
  • substr() - Retorna parte de uma string