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