(PHP 4, PHP 5, PHP 7, PHP 8)
strrpos — 文字列中に、ある部分文字列が最後に現れる場所を探す
$haystack
, string $needle
, int $offset
= 0): int|false
文字列 haystack
の中で、
needle
が最後に現れる位置を探します。
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 に数値を渡すことはサポートされなくなりました。
|
7.3.0 |
needle に数値を渡すことは非推奨になりました。
|
例1 needle が haystack の中にあるかどうかの確認
"位置 0 に文字が見つかった" と "文字が見つからなかった" 場合の戻り値は混同しやすいです。この違いを見分ける方法を以下に示します。
<?php
$pos = strrpos($mystring, "b");
if ($pos === false) { // 注意: 等号が 3 つ並んでいます
// 見つからない...
}
?>
例2 オフセットつきの検索
<?php
$foo = "0123456789a123456789b123456789c";
// Looking for '0' from the 0th byte (from the beginning)
var_dump(strrpos($foo, '0', 0));
// Looking for '0' from the 1st byte (after byte "0")
var_dump(strrpos($foo, '0', 1));
// Looking for '7' from the 21th byte (after byte 20)
var_dump(strrpos($foo, '7', 20));
// Looking for '7' from the 29th byte (after byte 28)
var_dump(strrpos($foo, '7', 28));
// Looking for '7' right to left from the 5th byte from the end
var_dump(strrpos($foo, '7', -5));
// Looking for 'c' right to left from the 2nd byte from the end
var_dump(strrpos($foo, 'c', -2));
// Looking for '9c' right to left from the 2nd byte from the end
var_dump(strrpos($foo, '9c', -2));
?>
上の例の出力は以下となります。
int(0) bool(false) int(27) bool(false) int(17) bool(false) int(29)