strpos
(PHP 4, PHP 5)
strpos — Cherche la position de la première occurrence dans une chaîne
Description
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. Contrairement aux fonctions strrpos() et strripos(), ce paramètre ne peut être négatif.
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.
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.
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
- stripos() - Recherche la position de la première occurrence dans une chaîne, sans tenir compte de la casse
- strrpos() - Cherche la position de la dernière occurrence d'une sous-chaine dans une chaîne
- strripos() - Cherche la position de la dernière occurrence d'une chaîne contenue dans une autre, de façon insensible à la casse
- strstr() - Trouve la première occurrence dans une chaîne
- strpbrk() - Recherche un ensemble de caractères dans une chaîne de caractères
- substr() - Retourne un segment de chaîne
- preg_match() - Expression rationnelle standard