(PHP 4, PHP 5, PHP 7, PHP 8)
strrpos — 計算指定字符串在目標(biāo)字符串中最后一次出現(xiàn)的位置
$haystack
, string $needle
, int $offset
= 0): int
返回字符串 haystack
中 needle
最后一次出現(xiàn)的數(shù)字位置。注意 PHP4 中,needle 只能為單個字符。如果 needle 被指定為一個字符串,那么將僅使用第一個字符。
haystack
在此字符串中進行查找。
needle
如果 needle
不是一個字符串,它將被轉(zhuǎn)換為整型并被視為字符的順序值。
offset
或許會查找字符串中任意長度的子字符串。負數(shù)值將導(dǎo)致查找在字符串結(jié)尾處開始的計數(shù)位置處結(jié)束。
返回 needle 存在的位置。如果沒有找到,返回 false
。
Also note that string positions start at 0, and not 1.
Returns false
if the needle was not found.
版本 | 說明 |
---|---|
5.0.0 |
參數(shù) needle 可以是一個多字符的字符串。
|
5.0.0 |
引入 offset 參數(shù)。
|
示例 #1 檢查字串是否存在
很容易將“在位置 0 處找到”和“未發(fā)現(xiàn)字符串”這兩種情況搞錯。這是檢測區(qū)別的辦法:
<?php
$pos = strrpos($mystring, "b");
if ($pos === false) { // 注意: 三個等號
// 未發(fā)現(xiàn)...
}
?>
示例 #2 使用偏移位置進行查找
<?php
$foo = "0123456789a123456789b123456789c";
var_dump(strrpos($foo, '7', -5)); // 從尾部第 5 個位置開始查找
// 結(jié)果: int(17)
var_dump(strrpos($foo, '7', 20)); // 從第 20 個位置開始查找
// 結(jié)果: int(27)
var_dump(strrpos($foo, '7', 28)); // 結(jié)果: bool(false)
?>