您好,登錄后才能下訂單哦!
這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)PHP中如何檢測(cè)子串是不是存在,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
而有時(shí)我們需要精確定位,進(jìn)行嚴(yán)格的檢測(cè),就需要區(qū)分大小寫(xiě)進(jìn)行查找。今天我們我們就來(lái)了解一下。
我們來(lái)看看下面一下示例
<?php header("Content-type:text/html;charset=utf-8"); $string = "ABCDCBAbcd"; $findme1 = "bC"; $findme2 = "bc"; $pos1 = strpos($string, $findme1); $pos2 = strrpos($string, $findme1); $pos3 = strpos($string, $findme2); $pos4 = strrpos($string, $findme2); if($pos1 !=FALSE){ echo "子串 '$findme1' 在字符串 '$string' 中存在。"; }else{ echo "子串 '$findme1' 在字符串 '$string' 中不存在。"; } if($pos2 !=FALSE){ echo "<br>子串 '$findme1' 在字符串 '$string' 中存在。"; }else{ echo "<br>子串 '$findme1' 在字符串 '$string' 中不存在。"; } if($pos3 !=FALSE){ echo "<br>子串 '$findme2' 在字符串 '$string' 中存在。"; }else{ echo "<br>子串 '$findme2' 在字符串 '$string' 中不存在。"; } if($pos4 !=FALSE){ echo "<br>子串 '$findme2' 在字符串 '$string' 中存在。"; }else{ echo "<br>子串 '$findme2' 在字符串 '$string' 中不存在。"; } ?>
strpos()和strrpos()函數(shù)會(huì)區(qū)分大小寫(xiě)的在字符串$string
中查找子串$findme1
或者$findme2
。當(dāng)完全匹配上,存在子串時(shí),會(huì)返回子串在字符串的第一次或最后一次的出現(xiàn)位置;如果在字符串的沒(méi)有找到子串,則返回FALSE
。
從上面的例子可以看出,只有子串"bc
"和字符串“ABCDCBAbcd
”是完全匹配,子串"bc
"被認(rèn)為是存在于字符串“ABCDCBAbcd
”中的。因此輸出結(jié)果為:
下面我們來(lái)詳細(xì)了解一下strpos()和strrpos()函數(shù)。
strpos($string,$find,$start)
函數(shù)可以返回子字符串首次出現(xiàn)的位置(區(qū)分大小寫(xiě));
strrpos($string,$find,$start)
函數(shù)可以返回子字符串最后一次出現(xiàn)的位置(區(qū)分大小寫(xiě));
strpos()和strrpos()函數(shù)相似,都接受兩個(gè)必需參數(shù)$string
(被查找的字符串)和$find
(要查找的子串),一個(gè)可省略參數(shù)$start
(查找的開(kāi)始位置)。注:字符串位置起始于 0,而不是 1。
<?php header("Content-type:text/html;charset=utf-8"); $string = "ABCabcabcABC"; $findme1 = "c"; $findme2 = "C"; echo "子串 '$findme1' 第一次出現(xiàn)的位置:".strpos($string, $findme1); echo "<br>子串 '$findme1' 最后一次出現(xiàn)的位置:".strrpos($string, $findme1); echo "<br>子串 '$findme2' 第一次出現(xiàn)的位置:".strpos($string, $findme2); echo "<br>子串 '$findme2' 最后一次出現(xiàn)的位置:".strrpos($string, $findme2); ?>
輸出結(jié)果:
但strrpos()函數(shù)的參數(shù)$start
可以接受負(fù)值,當(dāng)它為負(fù)數(shù)時(shí),將會(huì)導(dǎo)致查找在字符串結(jié)尾處開(kāi)始的計(jì)數(shù)位置處結(jié)束。
<?php header("Content-type:text/html;charset=utf-8"); $string = "ABCabcabcABC"; $findme1 = "c"; $findme2 = "C"; echo "子串 '$findme1' 第一次出現(xiàn)的位置:".strpos($string, $findme1); echo "<br>子串 '$findme1' 最后一次出現(xiàn)的位置:".strrpos($string, $findme1,-5); echo "<br>子串 '$findme2' 第一次出現(xiàn)的位置:".strpos($string, $findme2); echo "<br>子串 '$findme2' 最后一次出現(xiàn)的位置:".strrpos($string, $findme2,-5); ?>
輸出結(jié)果:
上述就是小編為大家分享的PHP中如何檢測(cè)子串是不是存在了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。