PHP 8.1.15 Released!

str_contains

(PHP 8)

str_containsDetermina se uma string contém uma substring fornecida

Descrição

str_contains(string $haystack, string $needle): bool

Realiza uma busca case-sensitive indicando se needle existe em haystack.

Parâmetros

haystack

A string onde será feita a busca.

needle

A substring para ser buscada em haystack.

Valor Retornado

Retorna true se needle está em haystack, false caso contrário.

Exemplos

Exemplo #1 Usando a string vazia ''

<?php
if (str_contains('abc', '')) {
echo
"Verificando a existência de uma string vazia sempre retornará true";
}
?>

O exemplo acima irá imprimir:

Verificando a existência de uma string vazia sempre retornará true

Exemplo #2 Mostrando o case-sensitivity

<?php
$string
= 'A raposa preguiçosa pulou a cerca';

if (
str_contains($string, 'raposa')) {
echo
"A string 'raposa' foi encontrada na string\n";
}

if (
str_contains($string, 'Raposa')) {
echo
'A string "Raposa" foi encontrada na string';
} else {
echo
'"Raposa" não foi encontrada porque o case não corresponde';
}

?>

O exemplo acima irá imprimir:

A string 'raposa' foi encontrada na string
"Raposa" não foi encontrada porque o case não corresponde

Notas

Nota: Esta função é binary-safe.

Veja Também

  • str_ends_with() - Verifica se uma string termina com uma substring fornecida
  • str_starts_with() - Verifica se uma string começa com uma substring fornecida
  • stripos() - Encontra a primeira ocorrencia de uma string sem diferenciar maiúsculas e minúsculas
  • strrpos() - Encontra a posição da última ocorrência de um caractere em uma string
  • strripos() - Encontra a posição da última ocorrência de uma string case-insensitive em uma string
  • strstr() - Encontra a primeira ocorrencia de uma string
  • strpbrk() - Procura na string por um dos caracteres de um conjunto
  • substr() - Retorna uma parte de uma string
  • preg_match() - Perform a regular expression match

add a note

User Contributed Notes 7 notes

up
78
scm6079
1 year ago
For earlier versions of PHP, you can polyfill the str_contains function using the following snippet:

<?php
// based on original work from the PHP Laravel framework
if (!function_exists('str_contains')) {
    function
str_contains($haystack, $needle) {
        return
$needle !== '' && mb_strpos($haystack, $needle) !== false;
    }
}
?>
up
6
aisunny7 dot xy at gmail dot com
1 year ago
The polyfill that based on original work from the PHP Laravel framework had a different behavior;

when the $needle is `""` or `null`:
php8's will return `true`;
but, laravel'str_contains will return `false`;

when php8.1, null is deprecated, You can use `$needle ?: ""`;
up
1
drupalista dot com dot br at gmail dot com
9 months ago
private function contains(array $needles, string $type, string $haystack = NULL, string $filename = NULL) : bool {
        if (empty($needles)) return FALSE;
        if ($filename)
            $haystack = file_get_contents($filename);

        $now_what = function(string $needle) use ($haystack, $type) : array {
            $has_needle = str_contains($haystack, $needle);
            if ($type === 'any' && $has_needle)
                return ['done' => TRUE, 'return' => TRUE];

            if ($type === 'all' && !$has_needle)
                return ['done' => TRUE, 'return' => FALSE];

            return ['done' => FALSE];
        };

        foreach ($needles as $needle) {
            $check = $now_what($needle);
            if ($check['done'])
                return $check['return'];
        }
        return TRUE;
    }

    function containsAny(array $needles, string $haystack = NULL, string $filename = NULL) : bool {
        return self::contains($needles, 'any', $haystack, $filename);
    }

    function containsAll(array $needles, string $haystack = NULL, string $filename = NULL) : bool {
        return self::contains($needles, 'all', $haystack, $filename);
    }
up
3
juliyvchirkov at gmail dot com
1 year ago
<?php

// Polyfill for PHP 4 - PHP 7, safe to utilize with PHP 8

if (!function_exists('str_contains')) {
    function
str_contains (string $haystack, string $needle)
    {
        return empty(
$needle) || strpos($haystack, $needle) !== false;
    }
}
up
0
olivertasche+nospam at gmail dot com
1 year ago
The code from "me at daz dot co dot uk" will not work if the word is
- at the start of the string
- at the end of the string
- at the end of a sentence (like "the ox." or "is that an ox?")
- in quotes
- and so on.

You should explode the string by whitespace, punctations, ... and check if the resulting array contains your word OR try to test with a RegEx like this:
(^|[\s\W])+word($|[\s\W])+

Disclaimer: The RegEx may need some tweaks
up
-9
AuxData
1 year ago
Until PHP 8 was released, many-a-programmer were writing our own contain() functions. Mine also handles needles with logical ORs (set to '||').
Here it is.

function contains($haystack, $needle, $offset){
    $OR = '||';
    $result = false;
   
    $ORpos = strpos($needle, $OR, 0);
    if($ORpos !== false){ //ORs exist in the needle string
        $needle_arr = explode($OR, $needle);
        for($i=0; $i < count($needle_arr); $i++){
            $pos = strpos($haystack, trim($needle_arr[$i]), $offset);
            if($pos !== false){
                $result = true;
                break;
            }
        }       
    } else {
        $pos = strpos($haystack, trim($needle), $offset);
        if($pos !== false){
          $result = true;
        }
    }
  return($result);
}

Call: contains("Apple Orange Banana", "Apple || Walnut", 0);
Returns: true
up
-42
kadenskinner at gmail dot com
1 year ago
<?php

$needle
= '@';
$haystack = 'user@example.com';

if (!
str_contains($haystack, $needle)){
echo
'There is not an @ in haystack';
}else{
echo
'There is an @ in haystack';
}
To Top