(PHP 4, PHP 5)
strpos — Cherche la position de la première occurrence dans une chaîne
Cherche la position numérique de la première occurrence de
needle
dans la chaîne de caractères
haystack
.
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. Contrairement aux fonctions strrpos() et strripos(), ce paramètre ne peut être négatif.
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.
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.
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
?>
Note: Cette fonction gère les chaînes binaires.