betterCode() PHP 2025

strripos

(PHP 5, PHP 7, PHP 8)

strriposИщет в строке позицию последнего вхождения подстроки, без учёта регистра

Описание

strripos(string $haystack, string $needle, int $offset = 0): int|false

Функция ищет позицию последнего вхождения подстроки needle в строку haystack.

Функция strripos() не учитывает регистр символов, в отличие от функции strrpos().

Список параметров

haystack

Строка, в которой выполняется поиск.

needle

Строка, которую требуется найти.

До PHP 8.0.0 нестроковый аргумент needle преобразовывался в целое число и заменялся на символ с этим порядковым значением в однобайтовой таблице символов. Начиная с PHP 7.3.0 передача нестроковых значений устарела и полагаться на него настоятельно не рекомендуют. Перед вызовом функции нестроковый аргумент needle требовалось либо приводить к строке, либо получать строковое значение символа функцией chr().

offset

При передаче нуля или положительного значения функция пропускает с начала строки haystack байты, количество которых указали в параметре offset, и начинает поиск слева направо.

При отрицательных значениях функция пропускает с конца строки haystack байты, количество которых указали в параметре offset, и начинает поиск первого вхождения подстроки needle при движении справа налево.

Замечание:

Функция ищет последнее вхождение подстроки needle, если представить поиск как движение с начала строки до точки перед смещением с конца строки в байтах, количество которых указали в параметре offset.

Возвращаемые значения

Функция возвращает числовую позицию последнего вхождения подстроки относительно начала строки haystack независимо от направления поиска и смещения.

Замечание: Позици строки начинаются с 0, а не с 1.

Функция возвращет значение false, если строка не содержит подстроку.

Внимание

Функция возвращает как логическое значение false, так и нелогическое значение, которое приводится к false. Прочитайте раздел «Логический тип», чтобы получить дополнительную информацию. Используйте оператор === для проверки значения, которое возвращает функция.

Список изменений

Версия Описание
8.2.0 Приведение к единому регистру больше не зависит от региональных настроек, которые установили функцией setlocale(). Преобразовываются только символы кодировки ASCII. Байты, которые не относятся к кодировке ASCII, сравнятся по значению байта.
8.0.0 Параметр needle теперь разрешает пустую строку.
8.0.0 Функция перестала поддерживать передачу целого числа (int) в параметр needle.
7.3.0 Передача целого числа (int) в needle устарела.

Примеры

Пример #1 Пример поиска позиции последнего вхождения подстроки функцией strripos()

<?php

$haystack
= 'ababcd';
$needle = 'aB';

$pos = strripos($haystack, $needle);

if (
$pos === false) {
echo
"Функция не в строке ($haystack) подстроку ($needle)";
} else {
echo
"Поздравляем!\n";
echo
"Функция нашла в строке ($haystack) подстроку ($needle) на позиции ($pos)";
}

?>

Результат выполнения приведённого примера:

Поздравляем!
Функция нашла в строке (ababcd) подстроку (aB) на позиции (2)

Смотрите также

  • strpos() - Ищет позицию первого вхождения подстроки
  • stripos() - Возвращает позицию первого вхождения подстроки без учёта регистра
  • strrpos() - Возвращает позицию последнего вхождения подстроки в строку
  • strrchr() - Находит последнее вхождение символа в строке
  • stristr() - Регистронезависимый вариант функции strstr
  • substr() - Возвращает подстроку

Добавить

Примечания пользователей 6 notes

up
5
Yanik Lupien
18 years ago
Simple way to implement this function in PHP 4

<?php
if (function_exists('strripos') == false) {
function
strripos($haystack, $needle) {
return
strlen($haystack) - strpos(strrev($haystack), $needle);
}
}

?>
up
2
dimmav at in dot gr
17 years ago
Suppose you just need a stripos function working backwards expecting that strripos does this job, you better use the following code of a custom function named strbipos:

<?php
function strbipos($haystack="", $needle="", $offset=0) {
// Search backwards in $haystack for $needle starting from $offset and return the position found or false

$len = strlen($haystack);
$pos = stripos(strrev($haystack), strrev($needle), $len - $offset - 1);
return ( (
$pos === false) ? false : $len - strlen($needle) - $pos );
}

// Test
$body = "01234Xy7890XYz456xy90";
$str = "xY";
$len = strlen($body);
echo
"TEST POSITIVE offset VALUES IN strbipos<br>";
for (
$i = 0; $i < $len; $i++) {
echo
"Search in [$body] for [$str] starting from offset [$i]: [" . strbipos($body, $str, $i) . "]<br>";
}
?>

Note that this function does exactly what it says and its results are different comparing to PHP 5 strripos function.
up
1
peev[dot]alexander at gmail dot com
18 years ago
I think you shouldn't underestimate the length of $needle in the search of THE FIRST POSITION of it's last occurrence in the string. I improved the posted function, with added support for offset. I think this is an exact copy of the real function:

<?php
if(!function_exists("strripos")){
function
strripos($haystack, $needle, $offset=0) {
if(
$offset<0){
$temp_cut = strrev( substr( $haystack, 0, abs($offset) ) );
}
else{
$temp_cut = strrev( substr( $haystack, $offset ) );
}
$pos = strlen($haystack) - (strpos($temp_cut, strrev($needle)) + $offset + strlen($needle));
if (
$pos == strlen($haystack)) { $pos = 0; }
return
$pos;
}
/* endfunction strripos*/
}/* endfunction exists strripos*/
?>
up
-1
peev[dot]alexander at gmail dot com
17 years ago
OK, I guess this will be the final function implementation for PHP 4.x versions ( my previous posts are invalid )

<?php

if(!function_exists("stripos")){
function
stripos( $str, $needle, $offset = 0 ){
return
strpos( strtolower( $str ), strtolower( $needle ), $offset );
}
/* endfunction stripos */
}/* endfunction exists stripos */

if(!function_exists("strripos")){
function
strripos( $haystack, $needle, $offset = 0 ) {
if( !
is_string( $needle ) )$needle = chr( intval( $needle ) );
if(
$offset < 0 ){
$temp_cut = strrev( substr( $haystack, 0, abs($offset) ) );
}
else{
$temp_cut = strrev( substr( $haystack, 0, max( ( strlen($haystack) - $offset ), 0 ) ) );
}
if( (
$found = stripos( $temp_cut, strrev($needle) ) ) === FALSE )return FALSE;
$pos = ( strlen( $haystack ) - ( $found + $offset + strlen( $needle ) ) );
return
$pos;
}
/* endfunction strripos */
}/* endfunction exists strripos */
?>
up
-2
Anonymous
15 years ago
Generally speaking, linear searches are from start to end, not end to start - which makes sense from a human perspective. If you need to find strings in a string backwards, reverse your haystack and needle rather than manually chopping it up.
up
-3
ElectroFox
18 years ago
Sorry, I made that last post a bit prematurely. One more thing wrong with the simple php4 version is that it breaks if the string is not found. It should actually look like this:

<?php
if (function_exists('strripos') == false) {
function
strripos($haystack, $needle) {
$pos = strlen($haystack) - strpos(strrev($haystack), strrev($needle));
if (
$pos == strlen($haystack)) { $pos = 0; }
return
$pos;
}
}
?>

Note, we now check to see if the $needle was found, and if it isn't, we return 0.
To Top