Fonctions sur les chaînes de caractères
PHP Manual

strpos

(PHP 4, PHP 5, PHP 7)

strposCherche la position de la première occurrence dans une chaîne

Description

int strpos ( string $haystack , mixed $needle [, int $offset = 0 ] )

Cherche la position numérique de la première occurrence de needle dans la chaîne de caractères haystack.

Liste de paramètres

haystack

La chaîne dans laquelle on doit chercher.

needle

Si needle n'est pas une chaîne, il est converti en entier, et utilisé comme caractère de code ASCII correspondant.

offset

Si spécifié, la recherche commencera à partir de ce nombre de caractères compté depuis le début de la chaîne. Si ce nombre est négatif, la recherche commencera en utilisant ce nombre de caractères mais en commençant par la fin de la chaîne.

Valeurs de retour

Retourne la position numérique de l'occurrence relativement au début de la chaîne haystack (indépendamment de l'offset). Notez également que la position dans la chaîne commence à 0, et non pas à 1.

Retourne FALSE si l'occurrence n'a pas été trouvée.

Avertissement

Cette fonction peut retourner FALSE, mais elle peut aussi retourner une valeur équivalent à FALSE. Veuillez lire la section sur les booléens pour plus d'informations. Utilisez l'opérateur === pour tester la valeur de retour exacte de cette fonction.

Historique

Version Description
7.1.0 Ajout du support des nombres négatifs pour le paramètre offset.

Exemples

Exemple #1 Avec ===

<?php
$mystring 
'abc';
$findme   'a';
$pos strpos($mystring$findme);

// Notez notre utilisation de ===.  == ne fonctionnerait pas comme attendu
// car la position de 'a' est la 0-ième (premier) caractère.
if ($pos === false) {
    echo 
"La chaîne '$findme' ne se trouve pas dans la chaîne '$mystring'";
} else {
    echo 
"La chaine '$findme' a été trouvée dans la chaîne '$mystring'";
    echo 
" et débute à la position $pos";
}
?>

Exemple #2 Avec !==

<?php
$mystring 
'abc';
$findme   'a';
$pos strpos($mystring$findme);

// Notez notre utilisation de !==.  != ne fonctionnerait pas comme attendu
// car la position de 'a' est la 0-ième (premier) caractère.
if ($pos !== false) {
    echo 
"La chaine '$findme' a été trouvée dans la chaîne '$mystring'";
    echo 
" et débute à la position $pos";
} else {
    echo 
"La chaîne '$findme' ne se trouve pas dans la chaîne '$mystring'";
}
?>

Exemple #3 Utiliser un offset

<?php
// Nous pouvons chercher le caractère, et ignorer tout ce qui est avant l'offset
$newstring 'abcdef abcdef';
$pos strpos($newstring'a'1); // $pos = 7, non pas 0
?>

Notes

Note: Cette fonction gère les chaînes binaires.

Voir aussi


Fonctions sur les chaînes de caractères
PHP Manual