php判断数组是否存在字符串中,php判断数组元素中是否存在某个字符串的方法_php技巧...
方法一:采用in_array(value,array,type)
type 可選。如果設(shè)置該參數(shù)為 true,則檢查搜索的數(shù)據(jù)與數(shù)組的值的類型是否相同。
$arr = array('可以','如何','方法','知道','沒有','不要');
//in_array(value,array,type)
$isin = in_array("如何2",$arr);
if($isin){
echo "in====".$isin;
}else{
echo "out====".$isin;
}
方法二:
array_key_exists 'array_key_exists() 函數(shù)判斷某個數(shù)組中是否存在指定的 key,如果該 key 存在,則返回 true,否則返回 false。array_key_exists(key,array
方法三:
array_search() 函數(shù)與 in_array() 一樣,在數(shù)組中查找一個鍵值。如果找到了該值,匹配元素的鍵名會被返回。如果沒找到,則返回 false。array_search(value,array,strict),當(dāng)數(shù)據(jù)量比較大的時候,用array_key_exists比較合適,但占用的內(nèi)存比較大,
數(shù)組結(jié)構(gòu)是: array(1, 2, 3, ..)和 array(1 => true, 2 => false, ..),內(nèi)存使用比值為1:2。
具體跟內(nèi)部實(shí)現(xiàn)有關(guān)系,在php中第一種和第二種的數(shù)據(jù)結(jié)構(gòu)類似,都是關(guān)聯(lián)數(shù)組。
其它補(bǔ)充:
查找一個元素是否在數(shù)組中,一共有下面三種做法:
in_array '函數(shù)在數(shù)組中搜索給定的值。in_array(value,array,type)type 可選。如果設(shè)置該參數(shù)為 true,則檢查搜索的數(shù)據(jù)與數(shù)組的值的類型是否相同。
array_key_exists 'array_key_exists() 函數(shù)判斷某個數(shù)組中是否存在指定的 key,如果該 key 存在,則返回 true,否則返回 false。
array_key_exists(key,array)
array_search 'array_search() 函數(shù)與 in_array() 一樣,在數(shù)組中查找一個鍵值。如果找到了該值,匹配元素的鍵名會被返回。如果沒找到,則返回 false。
array_search(value,array,strict)
從這里來看,在數(shù)據(jù)量不大的時候,比如小于1000,查找用哪一種都行,都不會成為瓶頸;
當(dāng)數(shù)據(jù)量比較大的時候,用array_key_exists比較合適。
當(dāng)然這里array_key_exists占用的內(nèi)存比較大,經(jīng)測算
數(shù)組結(jié)構(gòu)是: array(1, 2, 3, ..)和 array(1 => true, 2 => false, ..)
他們內(nèi)存使用比值為1:2;
這個和內(nèi)部實(shí)現(xiàn)有關(guān)系,實(shí)際上在php中第一種和第二種的數(shù)據(jù)結(jié)構(gòu)類似,都是關(guān)聯(lián)數(shù)組。
本文原創(chuàng)發(fā)布php中文網(wǎng),轉(zhuǎn)載請注明出處,感謝您的尊重!
總結(jié)
以上是生活随笔為你收集整理的php判断数组是否存在字符串中,php判断数组元素中是否存在某个字符串的方法_php技巧...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php 覆盖写文件内容,php写入文件不
- 下一篇: php写新闻浏览历史,PHP实现浏览历史