(PHP 5, PHP 7, PHP 8)
strripos — 文字列中で、特定の(大文字小文字を区別しない)文字列が最後に現れた位置を探す
haystack
検索対象の文字列。
needle
検索する文字列。
PHP 8.0.0 より前のバージョンでは、needle
が文字列でない場合、 数値に変換され、文字の通常の値として扱われていました。 この振る舞いは PHP 7.3.0 以降では推奨されないので、 この機能を使用しないことを強く推奨します。 意図した動作に依存する場合、 needle
を string に明示的にキャストするか、 明示的に chr() 関数を呼び出すべきでしょう。
offset
ゼロまたは正の値の場合、 haystack
の 最初の offset
バイトをスキップし、 左から右に検索が行われます。
負の値の場合、 haystack
の 最後の offset
バイトをスキップし、 右から左に検索が行われ、 needle
が最初に現れる場所を探します。
注意:
この方が、最後の
offset
バイトより前にある、 最後のneedle
を効率的に探せます。
needle が見つかった位置を、 haystack
文字列の先頭 (offset の値とは無関係) からの相対位置で返します。
注意: 文字列の開始位置は 0 であり、1 ではありません。
needle が見つからない場合は false
を返します。
バージョン | 説明 |
---|---|
8.0.0 | needle は、空文字列を受け入れるようになりました。 |
8.2.0 | ケースフォールディングは、setlocale() で設定されたロケールに依存しなくなりました。 ASCII のケースフォールディングのみが行われます。 ASCII でないバイト列は、バイト値として比較されます。 |
8.0.0 | needle に数値を渡すことはサポートされなくなりました。 |
7.3.0 | needle に数値を渡すことは非推奨になりました。 |
例1 単純な strripos() の例
<?php
$haystack = 'ababcd';
$needle = 'aB';
$pos = strripos($haystack, $needle);
if ($pos === false) {
echo "ごめんなさい、($needle) が ($haystack) の中に見つかりませんでした。";
} else {
echo "おめでとう!\n";
echo "($needle) が最後に ($haystack) に現れた位置は ($pos) です。";
}
?>
上の例の出力は以下となります。
おめでとう! (aB) が最後に (ababcd) に現れた位置は (2) です。