array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'tr', ), 'this' => array ( 0 => 'function.strrpos.php', 1 => 'strrpos', ), 'up' => array ( 0 => 'ref.strings.php', 1 => 'Dizge İşlevleri', ), 'prev' => array ( 0 => 'function.strripos.php', 1 => 'strripos', ), 'next' => array ( 0 => 'function.strspn.php', 1 => 'strspn', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'tr', 'path' => 'reference/strings/functions/strrpos.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 4, PHP 5, PHP 7, PHP 8)
strrpos — Bir dizgede bir karakterin sonuncusunu bulur
samanlık
dizgesi içindeki son
iğne
dizgesinin sayısal konumunu döndürür.
samanlık
İğnenin aranacağı dizge.
iğne
Aranacak dizge.
PHP 8.0.0 öncesinde, iğne
bir dizge değilse, bir
tamsayıya dönüştürülür ve bir karakterin sıra değeri olarak uygulanırdı.
PHP 7.3.0 itibariyle bu davranışın kullanımı önerilmemekte ve güvenilmemesi
önerilmektedir. Amaçlanan davranışa bağlı olarak,
iğne
ya doğrudan dizgeye çarpıtılmalı ya da doğrudan
bir chr() çağrısı yapılmalıdır.
başlangıç
Sıfır veya pozitifse samanlık
içinde ilk
başlangıç
bayt atlanıp arama soldan sağa
yapılır.
Negatif ise samanlık
içinde son
başlangıç
bayt atlanıp arama sağdan sola
yapılır.
Bilginize:
Bu aslında, son
başlangıç
bayttaki veya öncesindeki soniğne
nin konumunu bulmak için kullanılır.
Konumu samanlık
dizgesinin başına göre
(başlangıçtan ve arama yönünden bağımsız) bir tamsayı olarak döndürür.
Bilginize: Dizgenin ilk karakterinin konumu 1 değil 0'dır.
Eğer iğne
bulunamazsa, false
döner.
Bu işlev mantıksal false
değeriyle dönebileceği gibi false
olarak değerlendirilebilecek mantıksal
olmayan bir değerle de dönebilir. Bu konuda daha fazla bilgi
Mantıksal Değerler bölümünde
bulunabilir. Bu işlevden dönen değeri sınamak için
===
işleci kullanılabilir.
Sürüm: | Açıklama |
---|---|
8.0.0 |
iğne artık boş dizge kabul ediyor.
|
8.0.0 |
iğne olarak bir tamsayı aktarımı artık kabul
edilmiyor.
|
7.3.0 |
iğne olarak bir tamsayı aktarımı artık
önerilmiyor.
|
Örnek 1 - Samanlıkta iğne aramak
"Karakter 0. konumda bulundu" veya "Karakter yok" şeklinde dönen değer kolayca yanlış yorumlanabilir. Şimdi farkın nasıl ayırdedileceğini görelim:
<?php
$pos = strrpos($mystring, "b");
if ($pos === false) { // üçlü eşittire dikkat
// yokmuş...
}
?>
Örnek 2 - Başlangıç belirtmek
<?php
$foo = "0123456789a123456789b123456789c";
// Baştan 0. bayttan itibaren '0' bulmak için
var_dump(strrpos($foo, '0', 0));
// Baştan 1. bayttan itibaren (0. bayttan sonra) '0' bulmak için
var_dump(strrpos($foo, '0', 1));
// Baştan 21. bayttan itibaren (20. bayttan sonra) '7' bulmak için
var_dump(strrpos($foo, '7', 20));
// Baştan 29. bayttan itibaren (28. bayttan sonra) '7' bulmak için
var_dump(strrpos($foo, '7', 28));
// Sondan 5. bayttan itibaren sağdan sola doğru '7' bulmak için
var_dump(strrpos($foo, '7', -5));
// Sondan 2. bayttan itibaren sağdan sola doğru 'c' bulmak için
var_dump(strrpos($foo, 'c', -2));
// Sondan 2. bayttan itibaren sağdan sola doğru'9c' bulmak için
var_dump(strrpos($foo, '9c', -2));
?>
Yukarıdaki örneğin çıktısı:
int(0) bool(false) int(27) bool(false) int(17) bool(false) int(29)