PHP Velho Oeste 2024

mb_strpos

(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)

mb_strposEncontrar a posição da primeira ocorrência de uma string em outra

Descrição

mb_strpos(
    string $haystack,
    string $needle,
    int $offset = 0,
    ?string $encoding = null
): int|false

Encontra a posição da primeira ocorrência de uma string em outra string.

Realiza uma operação strpos() segura para multibyte com base no número de caracteres. A posição do primeiro caractere é 0, a posição do segundo caractere é 1, e assim por diante.

Parâmetros

haystack

A string sendo verificada.

needle

A string a ser encontrada em haystack. Em contraste com strpos(), valores numéricos não são aplicados como o valor ordinal de um caractere..

offset

O deslocamento da pesquisa. Se não for especificado, 0 é usado. Um deslocamento negativo conta a partir do final da string.

encoding

O parâmetro encoding é a codificação de caracteres. Se for omitido ou null, o valor da codificação de caracteres interna será usado.

Valor Retornado

Retorna a posição numérica da primeira ocorrência de needle na haystack string. Se needle não for encontrada, retorna false.

Registro de Alterações

Versão Descrição
8.0.0 O parâmetro needle agora aceita uma string vazia.
8.0.0 O parâmetro encoding agora pode ser nulo.
7.1.0 Suporte para deslocamentos negativos offset foi adicionado.

Veja Também

  • mb_internal_encoding() - Define/Obtém a codificação de caracteres interna
  • strpos() - Find the position of the first occurrence of a substring in a string

add a note add a note

User Contributed Notes 3 notes

up
3
stestagg at talk21 dot com
17 years ago
It appears that the $offset value is a character count not a byte count.  (This may seem obvious but it isn't explicitly stated)
up
-3
stestagg at talk21 dot com
17 years ago
a sample mb_str_replace function:

function mb_str_replace($haystack, $search,$replace, $offset=0,$encoding='auto'){
    $len_sch=mb_strlen($search,$encoding);
    $len_rep=mb_strlen($replace,$encoding);
   
    while (($offset=mb_strpos($haystack,$search,$offset,$encoding))!==false){
        $haystack=mb_substr($haystack,0,$offset,$encoding)
            .$replace
            .mb_substr($haystack,$offset+$len_sch,1000,$encoding);
        $offset=$offset+$len_rep;
        if ($offset>mb_strlen($haystack,$encoding))break;
    }
    return $haystack;
}
up
-19
stestagg at talk21 dot com
17 years ago
sorry, my previous post had an error.  replace the 1000 with strlen($haystack) to handle strings longer than 1000 chars.

btw. This is an issue with the mbstring functions.  you can't specify the $encoding without specifying a $length, thus this reduces the functionality of mb_substr compared to substr
To Top